diff options
author | Alexandre Flament <alex@al-f.net> | 2020-09-19 18:25:24 +0200 |
---|---|---|
committer | Alexandre Flament <alex@al-f.net> | 2020-09-22 11:57:06 +0200 |
commit | ad0758e52a900186f203c61373b6ef3c63240065 (patch) | |
tree | b1603ebec0f86d7f678fdbddbd2e45a981e91f22 /tests | |
parent | f9664037a6424bffc6a7bb7af9dcccc07e7c3d84 (diff) | |
download | searxng-ad0758e52a900186f203c61373b6ef3c63240065.tar.gz searxng-ad0758e52a900186f203c61373b6ef3c63240065.zip |
[mod] add searx/webutils.py
contains utility functions and classes used only by webapp.py
Diffstat (limited to 'tests')
-rw-r--r-- | tests/unit/test_utils.py | 59 | ||||
-rw-r--r-- | tests/unit/test_webutils.py | 65 |
2 files changed, 65 insertions, 59 deletions
diff --git a/tests/unit/test_utils.py b/tests/unit/test_utils.py index 08b759542..69f5ef92a 100644 --- a/tests/unit/test_utils.py +++ b/tests/unit/test_utils.py @@ -1,5 +1,4 @@ # -*- coding: utf-8 -*- -import mock from searx.testing import SearxTestCase from searx import utils @@ -16,25 +15,6 @@ class TestUtils(SearxTestCase): self.assertIsNotNone(utils.searx_useragent()) self.assertTrue(utils.searx_useragent().startswith('searx')) - def test_highlight_content(self): - self.assertEqual(utils.highlight_content(0, None), None) - self.assertEqual(utils.highlight_content(None, None), None) - self.assertEqual(utils.highlight_content('', None), None) - self.assertEqual(utils.highlight_content(False, None), None) - - contents = [ - '<html></html>' - 'not<' - ] - for content in contents: - self.assertEqual(utils.highlight_content(content, None), content) - - content = 'a' - query = 'test' - self.assertEqual(utils.highlight_content(content, query), content) - query = 'a test' - self.assertEqual(utils.highlight_content(content, query), content) - def test_html_to_text(self): html = """ <a href="/testlink" class="link_access_account"> @@ -56,15 +36,6 @@ class TestUtils(SearxTestCase): html = '<p><b>Lorem ipsum</i>dolor sit amet</p>' self.assertEqual(utils.html_to_text(html), "Lorem ipsum") - def test_prettify_url(self): - data = (('https://searx.me/', 'https://searx.me/'), - ('https://searx.me/ű', 'https://searx.me/ű'), - ('https://searx.me/' + (100 * 'a'), 'https://searx.me/[...]aaaaaaaaaaaaaaaaa'), - ('https://searx.me/' + (100 * 'ű'), 'https://searx.me/[...]űűűűűűűűűűűűűűűűű')) - - for test_url, expected in data: - self.assertEqual(utils.prettify_url(test_url, max_length=32), expected) - def test_match_language(self): self.assertEqual(utils.match_language('es', ['es']), 'es') self.assertEqual(utils.match_language('es', [], fallback='fallback'), 'fallback') @@ -124,33 +95,3 @@ class TestHTMLTextExtractor(SearxTestCase): text = '<p><b>Lorem ipsum</i>dolor sit amet</p>' with self.assertRaises(utils.HTMLTextExtractorException): self.html_text_extractor.feed(text) - - -class TestUnicodeWriter(SearxTestCase): - - def setUp(self): - self.unicode_writer = utils.UnicodeWriter(mock.MagicMock()) - - def test_write_row(self): - row = [1, 2, 3] - self.assertEqual(self.unicode_writer.writerow(row), None) - - def test_write_rows(self): - self.unicode_writer.writerow = mock.MagicMock() - rows = [1, 2, 3] - self.unicode_writer.writerows(rows) - self.assertEqual(self.unicode_writer.writerow.call_count, len(rows)) - - -class TestNewHmac(SearxTestCase): - - def test_bytes(self): - for secret_key in ['secret', b'secret', 1]: - if secret_key == 1: - with self.assertRaises(TypeError): - utils.new_hmac(secret_key, b'http://example.com') - continue - res = utils.new_hmac(secret_key, b'http://example.com') - self.assertEqual( - res, - '23e2baa2404012a5cc8e4a18b4aabf0dde4cb9b56f679ddc0fd6d7c24339d819') diff --git a/tests/unit/test_webutils.py b/tests/unit/test_webutils.py new file mode 100644 index 000000000..aa464688b --- /dev/null +++ b/tests/unit/test_webutils.py @@ -0,0 +1,65 @@ +# -*- coding: utf-8 -*- +import mock +from searx.testing import SearxTestCase +from searx import webutils + + +class TestWebUtils(SearxTestCase): + + def test_prettify_url(self): + data = (('https://searx.me/', 'https://searx.me/'), + ('https://searx.me/ű', 'https://searx.me/ű'), + ('https://searx.me/' + (100 * 'a'), 'https://searx.me/[...]aaaaaaaaaaaaaaaaa'), + ('https://searx.me/' + (100 * 'ű'), 'https://searx.me/[...]űűűűűűűűűűűűűűűűű')) + + for test_url, expected in data: + self.assertEqual(webutils.prettify_url(test_url, max_length=32), expected) + + def test_highlight_content(self): + self.assertEqual(webutils.highlight_content(0, None), None) + self.assertEqual(webutils.highlight_content(None, None), None) + self.assertEqual(webutils.highlight_content('', None), None) + self.assertEqual(webutils.highlight_content(False, None), None) + + contents = [ + '<html></html>' + 'not<' + ] + for content in contents: + self.assertEqual(webutils.highlight_content(content, None), content) + + content = 'a' + query = 'test' + self.assertEqual(webutils.highlight_content(content, query), content) + query = 'a test' + self.assertEqual(webutils.highlight_content(content, query), content) + + +class TestUnicodeWriter(SearxTestCase): + + def setUp(self): + self.unicode_writer = webutils.UnicodeWriter(mock.MagicMock()) + + def test_write_row(self): + row = [1, 2, 3] + self.assertEqual(self.unicode_writer.writerow(row), None) + + def test_write_rows(self): + self.unicode_writer.writerow = mock.MagicMock() + rows = [1, 2, 3] + self.unicode_writer.writerows(rows) + self.assertEqual(self.unicode_writer.writerow.call_count, len(rows)) + + +class TestNewHmac(SearxTestCase): + + def test_bytes(self): + for secret_key in ['secret', b'secret', 1]: + if secret_key == 1: + with self.assertRaises(TypeError): + webutils.new_hmac(secret_key, b'http://example.com') + continue + res = webutils.new_hmac(secret_key, b'http://example.com') + self.assertEqual( + res, + '23e2baa2404012a5cc8e4a18b4aabf0dde4cb9b56f679ddc0fd6d7c24339d819') |