kopia lustrzana https://github.com/dgtlmoon/changedetection.io
48 wiersze
1.3 KiB
Python
48 wiersze
1.3 KiB
Python
#!/usr/bin/python3
|
|
|
|
from . util import live_server_setup
|
|
from changedetectionio import html_tools
|
|
|
|
def test_setup(live_server):
|
|
live_server_setup(live_server)
|
|
|
|
# Unit test of the stripper
|
|
# Always we are dealing in utf-8
|
|
def test_strip_regex_text_func():
|
|
from ..processors import text_json_diff as fetch_site_status
|
|
|
|
test_content = """
|
|
but sometimes we want to remove the lines.
|
|
|
|
but 1 lines
|
|
skip 5 lines
|
|
really? yes man
|
|
#/not this tries weirdly formed regex or just strings starting with /
|
|
/not this
|
|
but including 1234 lines
|
|
igNORe-cAse text we dont want to keep
|
|
but not always."""
|
|
|
|
|
|
ignore_lines = [
|
|
"sometimes",
|
|
"/\s\d{2,3}\s/",
|
|
"/ignore-case text/",
|
|
"really?",
|
|
"/skip \d lines/i",
|
|
"/not"
|
|
]
|
|
|
|
stripped_content = html_tools.strip_ignore_text(test_content, ignore_lines)
|
|
|
|
assert b"but 1 lines" in stripped_content
|
|
assert b"igNORe-cAse text" not in stripped_content
|
|
assert b"but 1234 lines" not in stripped_content
|
|
assert b"really" not in stripped_content
|
|
assert b"not this" not in stripped_content
|
|
|
|
# Check line number reporting
|
|
stripped_content = html_tools.strip_ignore_text(test_content, ignore_lines, mode="line numbers")
|
|
assert stripped_content == [2, 5, 6, 7, 8, 10]
|
|
|