Left: | ||
Right: |
LEFT | RIGHT |
---|---|
1 # This file is part of Adblock Plus <https://adblockplus.org/>, | 1 # This file is part of Adblock Plus <https://adblockplus.org/>, |
2 # Copyright (C) 2006-2016 Eyeo GmbH | 2 # Copyright (C) 2006-2016 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 25 matching lines...) Expand all Loading... | |
36 | 36 |
37 @pytest.fixture | 37 @pytest.fixture |
38 def rootdir(tmpdir): | 38 def rootdir(tmpdir): |
39 """Directory with prepared list fragments.""" | 39 """Directory with prepared list fragments.""" |
40 rootdir = tmpdir.join('root') | 40 rootdir = tmpdir.join('root') |
41 rootdir.mkdir() | 41 rootdir.mkdir() |
42 # Simple file with just `Ok` and a non-ascii unicode character in it. | 42 # Simple file with just `Ok` and a non-ascii unicode character in it. |
43 rootdir.join('simple.txt').write('[Adblock]\nOk') | 43 rootdir.join('simple.txt').write('[Adblock]\nOk') |
44 # Fragment with a non-ascii character. | 44 # Fragment with a non-ascii character. |
45 rootdir.join('unicode.txt').write( | 45 rootdir.join('unicode.txt').write( |
46 u'[Adblock]\n\u1234'.encode('utf-8'), mode='wb') | 46 '[Adblock]\n\u1234'.encode('utf-8'), mode='wb') |
Sebastian Noack
2016/05/12 15:31:03
Since, for whatever reason, the qa env did run wit
Sebastian Noack
2016/05/27 12:54:55
I reverted changes of patch set 2. My conclusion a
| |
47 # Fragment with an include. | 47 # Fragment with an include. |
48 rootdir.join('includer.txt').write('[Adblock]\n%include inc:includee.txt%') | 48 rootdir.join('includer.txt').write('[Adblock]\n%include inc:includee.txt%') |
49 # Fragment that includes a circular include file. | 49 # Fragment that includes a circular include file. |
50 rootdir.join('circ.txt').write('[Adblock]\n%include inc:circular.txt%') | 50 rootdir.join('circ.txt').write('[Adblock]\n%include inc:circular.txt%') |
51 # Fragment that includes a file with broken include. | 51 # Fragment that includes a file with broken include. |
52 rootdir.join('brk.txt').write('[Adblock]\n%include inc:broken.txt%') | 52 rootdir.join('brk.txt').write('[Adblock]\n%include inc:broken.txt%') |
53 # Source directory for includes. | 53 # Source directory for includes. |
54 incdir = rootdir.join('inc') | 54 incdir = rootdir.join('inc') |
55 incdir.mkdir() | 55 incdir.mkdir() |
56 # Fragment that's included into includer.txt. | 56 # Fragment that's included into includer.txt. |
57 incdir.join('includee.txt').write('I am included!') | 57 incdir.join('includee.txt').write('I am included!') |
58 # Fragment that has a broken include. | 58 # Fragment that has a broken include. |
59 incdir.join('broken.txt').write('%include missing.txt%') | 59 incdir.join('broken.txt').write('%include missing.txt%') |
60 # Fragment that includes itself. | 60 # Fragment that includes itself. |
61 incdir.join('circular.txt').write('%include circular.txt%') | 61 incdir.join('circular.txt').write('%include circular.txt%') |
62 return rootdir | 62 return rootdir |
63 | 63 |
64 | 64 |
65 @pytest.fixture | 65 @pytest.fixture |
66 def webserver_port(tmpdir, request): | 66 def webserver_port(tmpdir, request): |
67 """Serve fragments via HTTP on a random port (return the port number).""" | 67 """Serve fragments via HTTP on a random port (return the port number).""" |
68 handler = SimpleHTTPServer.SimpleHTTPRequestHandler | 68 handler = SimpleHTTPServer.SimpleHTTPRequestHandler |
69 httpd = SocketServer.TCPServer(('', 0), handler) | 69 httpd = SocketServer.TCPServer(('', 0), handler) |
70 port = httpd.socket.getsockname()[1] | 70 port = httpd.socket.getsockname()[1] |
71 # Create some files to serve. | 71 # Create some files to serve. |
72 webroot = tmpdir.join('webroot') | 72 webroot = tmpdir.join('webroot') |
73 webroot.mkdir() | 73 webroot.mkdir() |
74 webroot.join('inc.txt').write(u'Web \u1234'.encode('utf-8'), mode='wb') | 74 webroot.join('inc.txt').write('Web \u1234'.encode('utf-8'), mode='wb') |
75 webroot.join('metainc.txt').write( | 75 webroot.join('metainc.txt').write( |
76 '%include http://localhost:{}/inc.txt%'.format(port)) | 76 '%include http://localhost:{}/inc.txt%'.format(port)) |
77 # Change to this directory and start the webserver in another thread. | 77 # Change to this directory and start the webserver in another thread. |
78 os.chdir(str(webroot)) | 78 os.chdir(str(webroot)) |
79 thread = threading.Thread(target=httpd.serve_forever) | 79 thread = threading.Thread(target=httpd.serve_forever) |
80 thread.setDaemon(True) | 80 thread.setDaemon(True) |
81 thread.start() | 81 thread.start() |
82 # Make sure we shut it down at the end of the test. | 82 # Make sure we shut it down at the end of the test. |
83 request.addfinalizer(httpd.shutdown) | 83 request.addfinalizer(httpd.shutdown) |
84 return port | 84 return port |
(...skipping 15 matching lines...) Expand all Loading... | |
100 | 100 |
101 def test_render_no_includes(rootdir, dstfile): | 101 def test_render_no_includes(rootdir, dstfile): |
102 run_script(str(rootdir.join('simple.txt')), str(dstfile)) | 102 run_script(str(rootdir.join('simple.txt')), str(dstfile)) |
103 result = dstfile.read() | 103 result = dstfile.read() |
104 assert 'Ok' in result | 104 assert 'Ok' in result |
105 assert '! Checksum:' in result | 105 assert '! Checksum:' in result |
106 | 106 |
107 | 107 |
108 def test_render_unicode(rootdir, dstfile): | 108 def test_render_unicode(rootdir, dstfile): |
109 code, err = run_script(str(rootdir.join('unicode.txt')), str(dstfile)) | 109 code, err = run_script(str(rootdir.join('unicode.txt')), str(dstfile)) |
110 assert u'\u1234' in dstfile.read(mode='rb').decode('utf-8') | 110 assert '\u1234' in dstfile.read(mode='rb').decode('utf-8') |
111 | 111 |
112 | 112 |
113 def test_render_with_includes(rootdir, dstfile): | 113 def test_render_with_includes(rootdir, dstfile): |
114 run_script(str(rootdir.join('includer.txt')), str(dstfile), | 114 run_script(str(rootdir.join('includer.txt')), str(dstfile), |
115 '-i', 'inc=' + str(rootdir.join('inc'))) | 115 '-i', 'inc=' + str(rootdir.join('inc'))) |
116 assert 'I am included!' in dstfile.read() | 116 assert 'I am included!' in dstfile.read() |
117 | 117 |
118 | 118 |
119 def test_render_with_includes_relative(rootdir, dstfile): | 119 def test_render_with_includes_relative(rootdir, dstfile): |
120 run_script('includer.txt', str(dstfile), '-i', 'inc=inc', cwd=str(rootdir)) | 120 run_script('includer.txt', str(dstfile), '-i', 'inc=inc', cwd=str(rootdir)) |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
171 assert err == "Unknown source: 'foo'\n" | 171 assert err == "Unknown source: 'foo'\n" |
172 | 172 |
173 | 173 |
174 @pytest.mark.tryfirst | 174 @pytest.mark.tryfirst |
175 @pytest.mark.slowtest | 175 @pytest.mark.slowtest |
176 def test_web_include(rootdir, dstfile, webserver_port): | 176 def test_web_include(rootdir, dstfile, webserver_port): |
177 url = 'http://localhost:{}/metainc.txt'.format(webserver_port) | 177 url = 'http://localhost:{}/metainc.txt'.format(webserver_port) |
178 webinc = rootdir.join('webinc.txt') | 178 webinc = rootdir.join('webinc.txt') |
179 webinc.write('[Adblock]\n%include {}%'.format(url)) | 179 webinc.write('[Adblock]\n%include {}%'.format(url)) |
180 code, err = run_script(str(webinc), str(dstfile)) | 180 code, err = run_script(str(webinc), str(dstfile)) |
181 assert u'Web \u1234' in dstfile.read(mode='rb').decode('utf-8') | 181 assert 'Web \u1234' in dstfile.read(mode='rb').decode('utf-8') |
182 | 182 |
183 | 183 |
184 @pytest.mark.slowtest | 184 @pytest.mark.slowtest |
185 def test_failed_web_include(rootdir, dstfile, webserver_port): | 185 def test_failed_web_include(rootdir, dstfile, webserver_port): |
186 url = 'http://localhost:{}/missing.txt'.format(webserver_port) | 186 url = 'http://localhost:{}/missing.txt'.format(webserver_port) |
187 webinc = rootdir.join('webinc.txt') | 187 webinc = rootdir.join('webinc.txt') |
188 webinc.write('[Adblock]\n%include {}%'.format(url)) | 188 webinc.write('[Adblock]\n%include {}%'.format(url)) |
189 code, err = run_script(str(webinc), str(dstfile)) | 189 code, err = run_script(str(webinc), str(dstfile)) |
190 assert code == 1 | 190 assert code == 1 |
191 assert err.startswith( | 191 assert err.startswith( |
192 "HTTP 404 Not found: '{0}' when including '{0}'".format(url)) | 192 "HTTP 404 Not found: '{0}' when including '{0}'".format(url)) |
LEFT | RIGHT |