diff options
author | Lars-Dominik Braun <lars@6xq.net> | 2018-11-01 20:53:24 +0100 |
---|---|---|
committer | Lars-Dominik Braun <lars@6xq.net> | 2018-11-03 09:44:13 +0100 |
commit | 2900786ee0b270d7abd3cd6935f618e4e46ce4f5 (patch) | |
tree | ecba7b60ebcb116630dcb27353f3bf2a4c37c520 /crocoite | |
parent | d61998a5196f8655e4a9303e19cf233b9d096b3f (diff) | |
download | crocoite-2900786ee0b270d7abd3cd6935f618e4e46ce4f5.tar.gz crocoite-2900786ee0b270d7abd3cd6935f618e4e46ce4f5.tar.bz2 crocoite-2900786ee0b270d7abd3cd6935f618e4e46ce4f5.zip |
html: Add tests for tag/attribute stripping
Diffstat (limited to 'crocoite')
-rw-r--r-- | crocoite/test_html.py | 38 |
1 files changed, 38 insertions, 0 deletions
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 ('<a>barbaz<b>foobar</b>.</a><b>foobar</b>.<b attr=1><c></c>') + stream = StripTagFilter (getTreeWalker ('etree')(d), ['b', 'c']) + serializer = HTMLSerializer () + assert serializer.render (stream) == '<a>barbaz.</a>.' + +def test_strip_attribute (): + d = html5lib.parse ('<a b=1 c="yes" d></a><br b=2 c="no" d keep=1>') + stream = StripAttributeFilter (getTreeWalker ('etree')(d), ['b', 'c', 'd']) + serializer = HTMLSerializer () + assert serializer.render (stream) == '<a></a><br keep=1>' + |