From 2900786ee0b270d7abd3cd6935f618e4e46ce4f5 Mon Sep 17 00:00:00 2001 From: Lars-Dominik Braun Date: Thu, 1 Nov 2018 20:53:24 +0100 Subject: html: Add tests for tag/attribute stripping --- crocoite/test_html.py | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 crocoite/test_html.py (limited to 'crocoite/test_html.py') diff --git a/crocoite/test_html.py b/crocoite/test_html.py new file mode 100644 index 0000000..bdd735a --- /dev/null +++ b/crocoite/test_html.py @@ -0,0 +1,38 @@ +# Copyright (c) 2017 crocoite contributors +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +# THE SOFTWARE. + +import pytest, html5lib +from html5lib.serializer import HTMLSerializer +from html5lib.treewalkers import getTreeWalker + +from .html import StripTagFilter, StripAttributeFilter + +def test_strip_tag (): + d = html5lib.parse ('barbazfoobar.foobar.') + stream = StripTagFilter (getTreeWalker ('etree')(d), ['b', 'c']) + serializer = HTMLSerializer () + assert serializer.render (stream) == 'barbaz..' + +def test_strip_attribute (): + d = html5lib.parse ('
') + stream = StripAttributeFilter (getTreeWalker ('etree')(d), ['b', 'c', 'd']) + serializer = HTMLSerializer () + assert serializer.render (stream) == '
' + -- cgit v1.2.3