diff options
| author | Gabor Nagy <mail@aigeruth.hu> | 2014-07-12 15:46:55 +0200 |
|---|---|---|
| committer | Gabor Nagy <mail@aigeruth.hu> | 2014-07-12 15:46:55 +0200 |
| commit | 8810273010afd91b0586f57d9c5794e7dd617d10 (patch) | |
| tree | 96c7aba66f2ea4b202bc1e141ea37be085f9ab12 /searx/tests/test_utils.py | |
| parent | e4419a065ffc7e8702453835e465a47b011b8f12 (diff) | |
Cover searx.utils
Diffstat (limited to 'searx/tests/test_utils.py')
| -rw-r--r-- | searx/tests/test_utils.py | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/searx/tests/test_utils.py b/searx/tests/test_utils.py new file mode 100644 index 000000000..817fd4372 --- /dev/null +++ b/searx/tests/test_utils.py @@ -0,0 +1,69 @@ +import mock +from searx.testing import SearxTestCase +from searx import utils + + +class TestUtils(SearxTestCase): + + def test_gen_useragent(self): + self.assertIsInstance(utils.gen_useragent(), str) + self.assertIsNotNone(utils.gen_useragent()) + self.assertTrue(utils.gen_useragent().startswith('Mozilla')) + + 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) + + +class TestHTMLTextExtractor(SearxTestCase): + + def setUp(self): + self.html_text_extractor = utils.HTMLTextExtractor() + + def test__init__(self): + self.assertEqual(self.html_text_extractor.result, []) + + def test_handle_charref(self): + self.html_text_extractor.handle_charref('xF') + self.assertIn(u'\x0f', self.html_text_extractor.result) + self.html_text_extractor.handle_charref('XF') + self.assertIn(u'\x0f', self.html_text_extractor.result) + + self.html_text_extractor.handle_charref('97') + self.assertIn(u'a', self.html_text_extractor.result) + + def test_handle_entityref(self): + entity = 'test' + self.html_text_extractor.handle_entityref(entity) + self.assertIn(entity, self.html_text_extractor.result) + + +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)) |