Left: | ||
Right: |
OLD | NEW |
---|---|
1 # This file is part of the Adblock Plus web scripts, | 1 # This file is part of the Adblock Plus web scripts, |
2 # Copyright (C) 2006-present eyeo GmbH | 2 # Copyright (C) 2006-present eyeo GmbH |
3 # | 3 # |
4 # Adblock Plus is free software: you can redistribute it and/or modify | 4 # Adblock Plus is free software: you can redistribute it and/or modify |
5 # it under the terms of the GNU General Public License version 3 as | 5 # it under the terms of the GNU General Public License version 3 as |
6 # published by the Free Software Foundation. | 6 # published by the Free Software Foundation. |
7 # | 7 # |
8 # Adblock Plus is distributed in the hope that it will be useful, | 8 # Adblock Plus is distributed in the hope that it will be useful, |
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of | 9 # but WITHOUT ANY WARRANTY; without even the implied warranty of |
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
51 | 51 |
52 @pytest.fixture(autouse=True) | 52 @pytest.fixture(autouse=True) |
53 def urlopen(mocker): | 53 def urlopen(mocker): |
54 """Mock urlopen function""" | 54 """Mock urlopen function""" |
55 real_urlopen = urllib2.urlopen | 55 real_urlopen = urllib2.urlopen |
56 | 56 |
57 def mock_urlopen(url): | 57 def mock_urlopen(url): |
58 if url.startswith('good'): | 58 if url.startswith('good'): |
59 zf_data = io.BytesIO() | 59 zf_data = io.BytesIO() |
60 with zipfile.ZipFile(zf_data, 'w') as zf: | 60 with zipfile.ZipFile(zf_data, 'w') as zf: |
61 zf.writestr('justdomains', 'success\n') | 61 idna_url = 'xn--xhq02ykwbp4a.cn\n' |
Vasily Kuznetsov
2018/07/03 16:01:52
I think it would make sense to have 2 domains in t
Tudor Avram
2018/07/06 11:53:16
Done.
| |
62 zf.writestr('justdomains', idna_url) | |
62 return io.BytesIO(zf_data.getvalue()) | 63 return io.BytesIO(zf_data.getvalue()) |
63 if url.startswith('bad'): | 64 if url.startswith('bad'): |
64 raise urllib2.HTTPError('Bad', '42', 'No good', [], None) | 65 raise urllib2.HTTPError('Bad', '42', 'No good', [], None) |
65 if url.startswith('ugly'): | 66 if url.startswith('ugly'): |
66 raise urllib2.URLError('Ugly') | 67 raise urllib2.URLError('Ugly') |
67 return real_urlopen(url) | 68 return real_urlopen(url) |
68 | 69 |
69 mocker.patch('urllib2.urlopen', mock_urlopen) | 70 mocker.patch('urllib2.urlopen', mock_urlopen) |
70 | 71 |
71 | 72 |
72 def test_good(md_repo): | 73 def test_good(md_repo): |
73 main() | 74 main() |
74 subprocess.check_call(['hg', 'up'], cwd=md_repo.strpath) | 75 subprocess.check_call(['hg', 'up'], cwd=md_repo.strpath) |
75 result = md_repo.join('malwaredomains_full.txt').read() | 76 result = md_repo.join('malwaredomains_full.txt').read() |
76 assert 'success' in result | 77 assert '.cn-w48dx81cufdl6b' in result |
77 | 78 |
78 | 79 |
79 def test_bad(md_repo, config): | 80 def test_bad(md_repo, config): |
80 config.set(CONF_SECTION, 'malwaredomains_mirrors', 'bad') | 81 config.set(CONF_SECTION, 'malwaredomains_mirrors', 'bad') |
81 try: | 82 try: |
82 main() | 83 main() |
83 except SystemExit as exc: | 84 except SystemExit as exc: |
84 err_lines = str(exc).splitlines() | 85 err_lines = str(exc).splitlines() |
85 assert len(err_lines) == 3 | 86 assert len(err_lines) == 3 |
86 assert 'Failed to fetch bad/files/justdomains.zip' in err_lines[2] | 87 assert 'Failed to fetch bad/files/justdomains.zip' in err_lines[2] |
87 assert '42: No good' in err_lines[2] | 88 assert '42: No good' in err_lines[2] |
88 | 89 |
89 | 90 |
90 def test_ugly(md_repo, config): | 91 def test_ugly(md_repo, config): |
91 config.set(CONF_SECTION, 'malwaredomains_mirrors', 'bad\nugly') | 92 config.set(CONF_SECTION, 'malwaredomains_mirrors', 'bad\nugly') |
92 try: | 93 try: |
93 main() | 94 main() |
94 except SystemExit as exc: | 95 except SystemExit as exc: |
95 err_lines = str(exc).splitlines() | 96 err_lines = str(exc).splitlines() |
96 assert len(err_lines) == 4 | 97 assert len(err_lines) == 4 |
97 assert 'Failed to fetch bad/files/justdomains.zip' in err_lines[2] | 98 assert 'Failed to fetch bad/files/justdomains.zip' in err_lines[2] |
98 assert 'Failed to fetch ugly/files/justdomains.zip' in err_lines[3] | 99 assert 'Failed to fetch ugly/files/justdomains.zip' in err_lines[3] |
99 assert 'Ugly' in err_lines[3] | 100 assert 'Ugly' in err_lines[3] |
OLD | NEW |