Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Side by Side Diff: test/matcher.js

Issue 29998564: Issue 7260 - Internalize third-party request check in matcher (Closed) Base URL: https://hg.adblockplus.org/adblockpluscore/
Patch Set: Created Feb. 5, 2019, 4:04 a.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | Download patch
« lib/matcher.js ('K') | « lib/matcher.js ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * This file is part of Adblock Plus <https://adblockplus.org/>, 2 * This file is part of Adblock Plus <https://adblockplus.org/>,
3 * Copyright (C) 2006-present eyeo GmbH 3 * Copyright (C) 2006-present eyeo GmbH
4 * 4 *
5 * Adblock Plus is free software: you can redistribute it and/or modify 5 * Adblock Plus is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 3 as 6 * it under the terms of the GNU General Public License version 3 as
7 * published by the Free Software Foundation. 7 * published by the Free Software Foundation.
8 * 8 *
9 * Adblock Plus is distributed in the hope that it will be useful, 9 * Adblock Plus is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
51 let dummyFilter = Filter.fromText("^" + keyword + "^"); 51 let dummyFilter = Filter.fromText("^" + keyword + "^");
52 dummyFilter.filterCount = Infinity; 52 dummyFilter.filterCount = Infinity;
53 matcher.add(dummyFilter); 53 matcher.add(dummyFilter);
54 } 54 }
55 } 55 }
56 56
57 test.equal(result.join(", "), expected.join(", "), "Keyword candidates for " + filter.text); 57 test.equal(result.join(", "), expected.join(", "), "Keyword candidates for " + filter.text);
58 } 58 }
59 } 59 }
60 60
61 function checkMatch(test, filters, location, contentType, docDomain, thirdParty, sitekey, specificOnly, expected, expectedFirstMatch = expected) 61 function checkMatch(test, filters, location, contentType, docDomain, sitekey, sp ecificOnly, expected, expectedFirstMatch = expected)
62 { 62 {
63 let matcher = new Matcher(); 63 let matcher = new Matcher();
64 for (let filter of filters) 64 for (let filter of filters)
65 matcher.add(Filter.fromText(filter)); 65 matcher.add(Filter.fromText(filter));
66 66
67 let result = matcher.matchesAny(location, RegExpFilter.typeMap[contentType], d ocDomain, thirdParty, sitekey, specificOnly); 67 let result = matcher.matchesAny(location, RegExpFilter.typeMap[contentType], d ocDomain, sitekey, specificOnly);
68 if (result) 68 if (result)
69 result = result.text; 69 result = result.text;
70 70
71 test.equal(result, expectedFirstMatch, "match(" + location + ", " + contentTyp e + ", " + docDomain + ", " + (thirdParty ? "third-party" : "first-party") + ", " + (sitekey || "no-sitekey") + ", " + (specificOnly ? "specificOnly" : "not-spe cificOnly") + ") with:\n" + filters.join("\n")); 71 test.equal(result, expectedFirstMatch, "match(" + location + ", " + contentTyp e + ", " + docDomain + ", " + (sitekey || "no-sitekey") + ", " + (specificOnly ? "specificOnly" : "not-specificOnly") + ") with:\n" + filters.join("\n"));
72 72
73 let combinedMatcher = new CombinedMatcher(); 73 let combinedMatcher = new CombinedMatcher();
74 for (let i = 0; i < 2; i++) 74 for (let i = 0; i < 2; i++)
75 { 75 {
76 for (let filter of filters) 76 for (let filter of filters)
77 combinedMatcher.add(Filter.fromText(filter)); 77 combinedMatcher.add(Filter.fromText(filter));
78 78
79 result = combinedMatcher.matchesAny(location, RegExpFilter.typeMap[contentTy pe], docDomain, thirdParty, sitekey, specificOnly); 79 result = combinedMatcher.matchesAny(location, RegExpFilter.typeMap[contentTy pe], docDomain, sitekey, specificOnly);
80 if (result) 80 if (result)
81 result = result.text; 81 result = result.text;
82 82
83 test.equal(result, expected, "combinedMatch(" + location + ", " + contentTyp e + ", " + docDomain + ", " + (thirdParty ? "third-party" : "first-party") + ", " + (sitekey || "no-sitekey") + ", " + (specificOnly ? "specificOnly" : "not-spe cificOnly") + ") with:\n" + filters.join("\n")); 83 test.equal(result, expected, "combinedMatch(" + location + ", " + contentTyp e + ", " + docDomain + ", " + (sitekey || "no-sitekey") + ", " + (specificOnly ? "specificOnly" : "not-specificOnly") + ") with:\n" + filters.join("\n"));
84 84
85 // Generic whitelisting rules can match for specificOnly searches, so we 85 // Generic whitelisting rules can match for specificOnly searches, so we
86 // can't easily know which rule will match for these whitelisting tests 86 // can't easily know which rule will match for these whitelisting tests
87 if (specificOnly) 87 if (specificOnly)
88 continue; 88 continue;
89 89
90 // For next run: add whitelisting filters for filters that aren't already 90 // For next run: add whitelisting filters for filters that aren't already
91 filters = filters.map(text => text.substr(0, 2) == "@@" ? text : "@@" + text ); 91 filters = filters.map(text => text.substr(0, 2) == "@@" ? text : "@@" + text );
92 if (expected && expected.substr(0, 2) != "@@") 92 if (expected && expected.substr(0, 2) != "@@")
93 expected = "@@" + expected; 93 expected = "@@" + expected;
94 } 94 }
95 } 95 }
96 96
97 function checkSearch(test, filters, location, contentType, docDomain, 97 function checkSearch(test, filters, location, contentType, docDomain,
98 thirdParty, sitekey, specificOnly, filterType, 98 sitekey, specificOnly, filterType, expected)
99 expected)
100 { 99 {
101 let matcher = new CombinedMatcher(); 100 let matcher = new CombinedMatcher();
102 for (let filter of filters) 101 for (let filter of filters)
103 matcher.add(Filter.fromText(filter)); 102 matcher.add(Filter.fromText(filter));
104 103
105 let result = matcher.search(location, RegExpFilter.typeMap[contentType], 104 let result = matcher.search(location, RegExpFilter.typeMap[contentType],
106 docDomain, thirdParty, sitekey, specificOnly, 105 docDomain, sitekey, specificOnly, filterType);
107 filterType);
108 for (let key in result) 106 for (let key in result)
109 result[key] = result[key].map(filter => filter.text); 107 result[key] = result[key].map(filter => filter.text);
110 108
111 test.deepEqual(result, expected, "search(" + location + ", " + 109 test.deepEqual(result, expected, "search(" + location + ", " +
112 contentType + ", " + docDomain + ", " + 110 contentType + ", " + docDomain + ", " +
113 (thirdParty ? "third-party" : "first-party") + ", " +
114 (sitekey || "no-sitekey") + ", " + 111 (sitekey || "no-sitekey") + ", " +
115 (specificOnly ? "specificOnly" : "not-specificOnly") + ", " + 112 (specificOnly ? "specificOnly" : "not-specificOnly") + ", " +
116 filterType + ") with:\n" + filters.join("\n")); 113 filterType + ") with:\n" + filters.join("\n"));
117 } 114 }
118 115
119 function cacheCheck(test, matcher, location, contentType, docDomain, thirdParty, expected) 116 function cacheCheck(test, matcher, location, contentType, docDomain, expected)
120 { 117 {
121 let result = matcher.matchesAny(location, RegExpFilter.typeMap[contentType], d ocDomain, thirdParty); 118 let result = matcher.matchesAny(location, RegExpFilter.typeMap[contentType], d ocDomain);
122 if (result) 119 if (result)
123 result = result.text; 120 result = result.text;
124 121
125 test.equal(result, expected, "match(" + location + ", " + contentType + ", " + docDomain + ", " + (thirdParty ? "third-party" : "first-party") + ") with stati c filters"); 122 test.equal(result, expected, "match(" + location + ", " + contentType + ", " + docDomain + ") with static filters");
126 } 123 }
127 124
128 exports.testMatcherClassDefinitions = function(test) 125 exports.testMatcherClassDefinitions = function(test)
129 { 126 {
130 test.equal(typeof Matcher, "function", "typeof Matcher"); 127 test.equal(typeof Matcher, "function", "typeof Matcher");
131 test.equal(typeof CombinedMatcher, "function", "typeof CombinedMatcher"); 128 test.equal(typeof CombinedMatcher, "function", "typeof CombinedMatcher");
132 test.equal(typeof defaultMatcher, "object", "typeof defaultMatcher"); 129 test.equal(typeof defaultMatcher, "object", "typeof defaultMatcher");
133 test.ok(defaultMatcher instanceof CombinedMatcher, "defaultMatcher is a Combin edMatcher instance"); 130 test.ok(defaultMatcher instanceof CombinedMatcher, "defaultMatcher is a Combin edMatcher instance");
134 131
135 test.done(); 132 test.done();
(...skipping 18 matching lines...) Expand all
154 compareKeywords(test, "_asdf_1234_", ["asdf", "1234"]); 151 compareKeywords(test, "_asdf_1234_", ["asdf", "1234"]);
155 compareKeywords(test, "+asdf-1234=", ["asdf", "1234"]); 152 compareKeywords(test, "+asdf-1234=", ["asdf", "1234"]);
156 compareKeywords(test, "/123^ad2&ad&", ["123", "ad2"]); 153 compareKeywords(test, "/123^ad2&ad&", ["123", "ad2"]);
157 compareKeywords(test, "/123^ad2&ad$script,domain=example.com", ["123", "ad2"]) ; 154 compareKeywords(test, "/123^ad2&ad$script,domain=example.com", ["123", "ad2"]) ;
158 155
159 test.done(); 156 test.done();
160 }; 157 };
161 158
162 exports.testFilterMatching = function(test) 159 exports.testFilterMatching = function(test)
163 { 160 {
164 checkMatch(test, [], "http://abc/def", "IMAGE", null, false, null, false, null ); 161 checkMatch(test, [], "http://abc/def", "IMAGE", "abc", null, false, null);
165 checkMatch(test, ["abc"], "http://abc/def", "IMAGE", null, false, null, false, "abc"); 162 checkMatch(test, ["abc"], "http://abc/def", "IMAGE", "abc", null, false, "abc" );
166 checkMatch(test, ["abc", "ddd"], "http://abc/def", "IMAGE", null, false, null, false, "abc"); 163 checkMatch(test, ["abc", "ddd"], "http://abc/def", "IMAGE", "abc", null, false , "abc");
167 checkMatch(test, ["ddd", "abc"], "http://abc/def", "IMAGE", null, false, null, false, "abc"); 164 checkMatch(test, ["ddd", "abc"], "http://abc/def", "IMAGE", "abc", null, false , "abc");
168 checkMatch(test, ["ddd", "abd"], "http://abc/def", "IMAGE", null, false, null, false, null); 165 checkMatch(test, ["ddd", "abd"], "http://abc/def", "IMAGE", "abc", null, false , null);
169 checkMatch(test, ["abc", "://abc/d"], "http://abc/def", "IMAGE", null, false, null, false, "://abc/d"); 166 checkMatch(test, ["abc", "://abc/d"], "http://abc/def", "IMAGE", "abc", null, false, "://abc/d");
170 checkMatch(test, ["://abc/d", "abc"], "http://abc/def", "IMAGE", null, false, null, false, "://abc/d"); 167 checkMatch(test, ["://abc/d", "abc"], "http://abc/def", "IMAGE", "abc", null, false, "://abc/d");
171 checkMatch(test, ["|http://"], "http://abc/def", "IMAGE", null, false, null, f alse, "|http://"); 168 checkMatch(test, ["|http://"], "http://abc/def", "IMAGE", "abc", null, false, "|http://");
172 checkMatch(test, ["|http://abc"], "http://abc/def", "IMAGE", null, false, null , false, "|http://abc"); 169 checkMatch(test, ["|http://abc"], "http://abc/def", "IMAGE", "abc", null, fals e, "|http://abc");
173 checkMatch(test, ["|abc"], "http://abc/def", "IMAGE", null, false, null, false , null); 170 checkMatch(test, ["|abc"], "http://abc/def", "IMAGE", "abc", null, false, null );
174 checkMatch(test, ["|/abc/def"], "http://abc/def", "IMAGE", null, false, null, false, null); 171 checkMatch(test, ["|/abc/def"], "http://abc/def", "IMAGE", "abc", null, false, null);
175 checkMatch(test, ["/def|"], "http://abc/def", "IMAGE", null, false, null, fals e, "/def|"); 172 checkMatch(test, ["/def|"], "http://abc/def", "IMAGE", "abc", null, false, "/d ef|");
176 checkMatch(test, ["/abc/def|"], "http://abc/def", "IMAGE", null, false, null, false, "/abc/def|"); 173 checkMatch(test, ["/abc/def|"], "http://abc/def", "IMAGE", "abc", null, false, "/abc/def|");
177 checkMatch(test, ["/abc/|"], "http://abc/def", "IMAGE", null, false, null, fal se, null); 174 checkMatch(test, ["/abc/|"], "http://abc/def", "IMAGE", "abc", null, false, nu ll);
178 checkMatch(test, ["http://abc/|"], "http://abc/def", "IMAGE", null, false, nul l, false, null); 175 checkMatch(test, ["http://abc/|"], "http://abc/def", "IMAGE", "abc", null, fal se, null);
179 checkMatch(test, ["|http://abc/def|"], "http://abc/def", "IMAGE", null, false, null, false, "|http://abc/def|"); 176 checkMatch(test, ["|http://abc/def|"], "http://abc/def", "IMAGE", "abc", null, false, "|http://abc/def|");
180 checkMatch(test, ["|/abc/def|"], "http://abc/def", "IMAGE", null, false, null, false, null); 177 checkMatch(test, ["|/abc/def|"], "http://abc/def", "IMAGE", "abc", null, false , null);
181 checkMatch(test, ["|http://abc/|"], "http://abc/def", "IMAGE", null, false, nu ll, false, null); 178 checkMatch(test, ["|http://abc/|"], "http://abc/def", "IMAGE", "abc", null, fa lse, null);
182 checkMatch(test, ["|/abc/|"], "http://abc/def", "IMAGE", null, false, null, fa lse, null); 179 checkMatch(test, ["|/abc/|"], "http://abc/def", "IMAGE", "abc", null, false, n ull);
183 checkMatch(test, ["||example.com/abc"], "http://example.com/abc/def", "IMAGE", null, false, null, false, "||example.com/abc"); 180 checkMatch(test, ["||example.com/abc"], "http://example.com/abc/def", "IMAGE", "example.com", null, false, "||example.com/abc");
184 checkMatch(test, ["||com/abc/def"], "http://example.com/abc/def", "IMAGE", nul l, false, null, false, "||com/abc/def"); 181 checkMatch(test, ["||com/abc/def"], "http://example.com/abc/def", "IMAGE", "ex ample.com", null, false, "||com/abc/def");
185 checkMatch(test, ["||com/abc"], "http://example.com/abc/def", "IMAGE", null, f alse, null, false, "||com/abc"); 182 checkMatch(test, ["||com/abc"], "http://example.com/abc/def", "IMAGE", "exampl e.com", null, false, "||com/abc");
186 checkMatch(test, ["||mple.com/abc"], "http://example.com/abc/def", "IMAGE", nu ll, false, null, false, null); 183 checkMatch(test, ["||mple.com/abc"], "http://example.com/abc/def", "IMAGE", "e xample.com", null, false, null);
187 checkMatch(test, ["||.com/abc/def"], "http://example.com/abc/def", "IMAGE", nu ll, false, null, false, null); 184 checkMatch(test, ["||.com/abc/def"], "http://example.com/abc/def", "IMAGE", "e xample.com", null, false, null);
188 checkMatch(test, ["||http://example.com/"], "http://example.com/abc/def", "IMA GE", null, false, null, false, null); 185 checkMatch(test, ["||http://example.com/"], "http://example.com/abc/def", "IMA GE", "example.com", null, false, null);
189 checkMatch(test, ["||example.com/abc/def|"], "http://example.com/abc/def", "IM AGE", null, false, null, false, "||example.com/abc/def|"); 186 checkMatch(test, ["||example.com/abc/def|"], "http://example.com/abc/def", "IM AGE", "example.com", null, false, "||example.com/abc/def|");
190 checkMatch(test, ["||com/abc/def|"], "http://example.com/abc/def", "IMAGE", nu ll, false, null, false, "||com/abc/def|"); 187 checkMatch(test, ["||com/abc/def|"], "http://example.com/abc/def", "IMAGE", "e xample.com", null, false, "||com/abc/def|");
191 checkMatch(test, ["||example.com/abc|"], "http://example.com/abc/def", "IMAGE" , null, false, null, false, null); 188 checkMatch(test, ["||example.com/abc|"], "http://example.com/abc/def", "IMAGE" , "example.com", null, false, null);
192 checkMatch(test, ["abc", "://abc/d", "asdf1234"], "http://abc/def", "IMAGE", n ull, false, null, false, "://abc/d"); 189 checkMatch(test, ["abc", "://abc/d", "asdf1234"], "http://abc/def", "IMAGE", " abc", null, false, "://abc/d");
193 checkMatch(test, ["foo*://abc/d", "foo*//abc/de", "://abc/de", "asdf1234"], "h ttp://abc/def", "IMAGE", null, false, null, false, "://abc/de"); 190 checkMatch(test, ["foo*://abc/d", "foo*//abc/de", "://abc/de", "asdf1234"], "h ttp://abc/def", "IMAGE", "abc", null, false, "://abc/de");
194 checkMatch(test, ["abc$third-party", "abc$~third-party", "ddd"], "http://abc/d ef", "IMAGE", null, false, null, false, "abc$~third-party"); 191 checkMatch(test, ["abc$third-party", "abc$~third-party", "ddd"], "http://abc/d ef", "IMAGE", "abc", null, false, "abc$~third-party");
195 checkMatch(test, ["abc$third-party", "abc$~third-party", "ddd"], "http://abc/d ef", "IMAGE", null, true, null, false, "abc$third-party"); 192 checkMatch(test, ["abc$third-party", "abc$~third-party", "ddd"], "http://abc/d ef", "IMAGE", "third-party-domain", null, false, "abc$third-party");
196 checkMatch(test, ["//abc/def$third-party", "//abc/def$~third-party", "//abc_de f"], "http://abc/def", "IMAGE", null, false, null, false, "//abc/def$~third-part y"); 193 checkMatch(test, ["//abc/def$third-party", "//abc/def$~third-party", "//abc_de f"], "http://abc/def", "IMAGE", "abc", null, false, "//abc/def$~third-party");
197 checkMatch(test, ["//abc/def$third-party", "//abc/def$~third-party", "//abc_de f"], "http://abc/def", "IMAGE", null, true, null, false, "//abc/def$third-party" ); 194 checkMatch(test, ["//abc/def$third-party", "//abc/def$~third-party", "//abc_de f"], "http://abc/def", "IMAGE", "third-party-domain", null, false, "//abc/def$th ird-party");
198 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def"], "http:/ /abc/def", "IMAGE", null, true, null, false, "//abc/def"); 195 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def"], "http:/ /abc/def", "IMAGE", "third-party-domain", null, false, "//abc/def");
199 checkMatch(test, ["//abc/def", "abc$third-party", "abc$~third-party"], "http:/ /abc/def", "IMAGE", null, true, null, false, "//abc/def"); 196 checkMatch(test, ["//abc/def", "abc$third-party", "abc$~third-party"], "http:/ /abc/def", "IMAGE", "third-party-domain", null, false, "//abc/def");
200 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def$third-part y"], "http://abc/def", "IMAGE", null, true, null, false, "//abc/def$third-party" ); 197 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def$third-part y"], "http://abc/def", "IMAGE", "third-party-domain", null, false, "//abc/def$th ird-party");
201 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def$third-part y"], "http://abc/def", "IMAGE", null, false, null, false, "abc$~third-party"); 198 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def$third-part y"], "http://abc/def", "IMAGE", "abc", null, false, "abc$~third-party");
202 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def$~third-par ty"], "http://abc/def", "IMAGE", null, true, null, false, "abc$third-party"); 199 checkMatch(test, ["abc$third-party", "abc$~third-party", "//abc/def$~third-par ty"], "http://abc/def", "IMAGE", "third-party-domain", null, false, "abc$third-p arty");
203 checkMatch(test, ["abc$image", "abc$script", "abc$~image"], "http://abc/def", "IMAGE", null, false, null, false, "abc$image"); 200 checkMatch(test, ["abc$image", "abc$script", "abc$~image"], "http://abc/def", "IMAGE", "abc", null, false, "abc$image");
204 checkMatch(test, ["abc$image", "abc$script", "abc$~script"], "http://abc/def", "SCRIPT", null, false, null, false, "abc$script"); 201 checkMatch(test, ["abc$image", "abc$script", "abc$~script"], "http://abc/def", "SCRIPT", "abc", null, false, "abc$script");
205 checkMatch(test, ["abc$image", "abc$script", "abc$~image"], "http://abc/def", "OTHER", null, false, null, false, "abc$~image"); 202 checkMatch(test, ["abc$image", "abc$script", "abc$~image"], "http://abc/def", "OTHER", "abc", null, false, "abc$~image");
206 checkMatch(test, ["//abc/def$image", "//abc/def$script", "//abc/def$~image"], "http://abc/def", "IMAGE", null, false, null, false, "//abc/def$image"); 203 checkMatch(test, ["//abc/def$image", "//abc/def$script", "//abc/def$~image"], "http://abc/def", "IMAGE", "abc", null, false, "//abc/def$image");
207 checkMatch(test, ["//abc/def$image", "//abc/def$script", "//abc/def$~script"], "http://abc/def", "SCRIPT", null, false, null, false, "//abc/def$script"); 204 checkMatch(test, ["//abc/def$image", "//abc/def$script", "//abc/def$~script"], "http://abc/def", "SCRIPT", "abc", null, false, "//abc/def$script");
208 checkMatch(test, ["//abc/def$image", "//abc/def$script", "//abc/def$~image"], "http://abc/def", "OTHER", null, false, null, false, "//abc/def$~image"); 205 checkMatch(test, ["//abc/def$image", "//abc/def$script", "//abc/def$~image"], "http://abc/def", "OTHER", "abc", null, false, "//abc/def$~image");
209 checkMatch(test, ["abc$image", "abc$~image", "//abc/def"], "http://abc/def", " IMAGE", null, false, null, false, "//abc/def"); 206 checkMatch(test, ["abc$image", "abc$~image", "//abc/def"], "http://abc/def", " IMAGE", "abc", null, false, "//abc/def");
210 checkMatch(test, ["//abc/def", "abc$image", "abc$~image"], "http://abc/def", " IMAGE", null, false, null, false, "//abc/def"); 207 checkMatch(test, ["//abc/def", "abc$image", "abc$~image"], "http://abc/def", " IMAGE", "abc", null, false, "//abc/def");
211 checkMatch(test, ["abc$image", "abc$~image", "//abc/def$image"], "http://abc/d ef", "IMAGE", null, false, null, false, "//abc/def$image"); 208 checkMatch(test, ["abc$image", "abc$~image", "//abc/def$image"], "http://abc/d ef", "IMAGE", "abc", null, false, "//abc/def$image");
212 checkMatch(test, ["abc$image", "abc$~image", "//abc/def$script"], "http://abc/ def", "IMAGE", null, false, null, false, "abc$image"); 209 checkMatch(test, ["abc$image", "abc$~image", "//abc/def$script"], "http://abc/ def", "IMAGE", "abc", null, false, "abc$image");
213 checkMatch(test, ["abc$domain=foo.com", "abc$domain=bar.com", "abc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "foo.com", false, null, false, "abc$ domain=foo.com"); 210 checkMatch(test, ["abc$domain=foo.com", "abc$domain=bar.com", "abc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "foo.com", null, false, "abc$domain= foo.com");
214 checkMatch(test, ["abc$domain=foo.com", "abc$domain=bar.com", "abc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "bar.com", false, null, false, "abc$ domain=bar.com"); 211 checkMatch(test, ["abc$domain=foo.com", "abc$domain=bar.com", "abc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "bar.com", null, false, "abc$domain= bar.com");
215 checkMatch(test, ["abc$domain=foo.com", "abc$domain=bar.com", "abc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "baz.com", false, null, false, "abc$ domain=~foo.com|~bar.com"); 212 checkMatch(test, ["abc$domain=foo.com", "abc$domain=bar.com", "abc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "baz.com", null, false, "abc$domain= ~foo.com|~bar.com");
216 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "foo.com", false, null, false, "abc$ domain=foo.com"); 213 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "foo.com", null, false, "abc$domain= foo.com");
217 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "bar.com", false, null, false, null) ; 214 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "bar.com", null, false, null);
218 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "baz.com", false, null, false, null) ; 215 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://abc/def", "IMAGE", "baz.com", null, false, null);
219 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://ccc/def", "IMAGE", "baz.com", false, null, false, "ccc$ domain=~foo.com|~bar.com"); 216 checkMatch(test, ["abc$domain=foo.com", "cba$domain=bar.com", "ccc$domain=~foo .com|~bar.com"], "http://ccc/def", "IMAGE", "baz.com", null, false, "ccc$domain= ~foo.com|~bar.com");
220 checkMatch(test, ["abc$sitekey=foo-publickey", "abc$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "foo.com", false, "foo-publickey", false, "abc$sitekey =foo-publickey"); 217 checkMatch(test, ["abc$sitekey=foo-publickey", "abc$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "foo.com", "foo-publickey", false, "abc$sitekey=foo-pu blickey");
221 checkMatch(test, ["abc$sitekey=foo-publickey", "abc$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "bar.com", false, "bar-publickey", false, "abc$sitekey =bar-publickey"); 218 checkMatch(test, ["abc$sitekey=foo-publickey", "abc$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "bar.com", "bar-publickey", false, "abc$sitekey=bar-pu blickey");
222 checkMatch(test, ["abc$sitekey=foo-publickey", "cba$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "bar.com", false, "bar-publickey", false, null); 219 checkMatch(test, ["abc$sitekey=foo-publickey", "cba$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "bar.com", "bar-publickey", false, null);
223 checkMatch(test, ["abc$sitekey=foo-publickey", "cba$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "baz.com", false, null, false, null); 220 checkMatch(test, ["abc$sitekey=foo-publickey", "cba$sitekey=bar-publickey"], " http://abc/def", "IMAGE", "baz.com", null, false, null);
224 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "foo.com", false, "foo-p ublickey", false, "abc$sitekey=foo-publickey,domain=foo.com"); 221 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "foo.com", "foo-publicke y", false, "abc$sitekey=foo-publickey,domain=foo.com");
225 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "foo.com", false, "bar-p ublickey", false, null); 222 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "foo.com", "bar-publicke y", false, null);
226 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "bar.com", false, "foo-p ublickey", false, null); 223 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "bar.com", "foo-publicke y", false, null);
227 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "bar.com", false, "bar-p ublickey", false, "abc$sitekey=bar-publickey,domain=bar.com"); 224 checkMatch(test, ["abc$sitekey=foo-publickey,domain=foo.com", "abc$sitekey=bar -publickey,domain=bar.com"], "http://abc/def", "IMAGE", "bar.com", "bar-publicke y", false, "abc$sitekey=bar-publickey,domain=bar.com");
228 checkMatch(test, ["@@foo.com$document"], "http://foo.com/bar", "DOCUMENT", "fo o.com", false, null, false, "@@foo.com$document"); 225 checkMatch(test, ["@@foo.com$document"], "http://foo.com/bar", "DOCUMENT", "fo o.com", null, false, "@@foo.com$document");
229 checkMatch(test, ["@@foo.com$elemhide"], "http://foo.com/bar", "ELEMHIDE", "fo o.com", false, null, false, "@@foo.com$elemhide"); 226 checkMatch(test, ["@@foo.com$elemhide"], "http://foo.com/bar", "ELEMHIDE", "fo o.com", null, false, "@@foo.com$elemhide");
230 checkMatch(test, ["@@foo.com$generichide"], "http://foo.com/bar", "GENERICHIDE ", "foo.com", false, null, false, "@@foo.com$generichide"); 227 checkMatch(test, ["@@foo.com$generichide"], "http://foo.com/bar", "GENERICHIDE ", "foo.com", null, false, "@@foo.com$generichide");
231 checkMatch(test, ["@@foo.com$genericblock"], "http://foo.com/bar", "GENERICBLO CK", "foo.com", false, null, false, "@@foo.com$genericblock"); 228 checkMatch(test, ["@@foo.com$genericblock"], "http://foo.com/bar", "GENERICBLO CK", "foo.com", null, false, "@@foo.com$genericblock");
232 checkMatch(test, ["@@bar.com$document"], "http://foo.com/bar", "DOCUMENT", "fo o.com", false, null, false, null); 229 checkMatch(test, ["@@bar.com$document"], "http://foo.com/bar", "DOCUMENT", "fo o.com", null, false, null);
233 checkMatch(test, ["@@bar.com$elemhide"], "http://foo.com/bar", "ELEMHIDE", "fo o.com", false, null, false, null); 230 checkMatch(test, ["@@bar.com$elemhide"], "http://foo.com/bar", "ELEMHIDE", "fo o.com", null, false, null);
234 checkMatch(test, ["@@bar.com$generichide"], "http://foo.com/bar", "GENERICHIDE ", "foo.com", false, null, false, null); 231 checkMatch(test, ["@@bar.com$generichide"], "http://foo.com/bar", "GENERICHIDE ", "foo.com", null, false, null);
235 checkMatch(test, ["@@bar.com$genericblock"], "http://foo.com/bar", "GENERICBLO CK", "foo.com", false, null, false, null); 232 checkMatch(test, ["@@bar.com$genericblock"], "http://foo.com/bar", "GENERICBLO CK", "foo.com", null, false, null);
236 checkMatch(test, ["/bar"], "http://foo.com/bar", "IMAGE", "foo.com", false, nu ll, true, null); 233 checkMatch(test, ["/bar"], "http://foo.com/bar", "IMAGE", "foo.com", null, tru e, null);
237 checkMatch(test, ["/bar$domain=foo.com"], "http://foo.com/bar", "IMAGE", "foo. com", false, null, true, "/bar$domain=foo.com"); 234 checkMatch(test, ["/bar$domain=foo.com"], "http://foo.com/bar", "IMAGE", "foo. com", null, true, "/bar$domain=foo.com");
238 checkMatch(test, ["@@||foo.com^"], "http://foo.com/bar", "IMAGE", "foo.com", f alse, null, false, null, "@@||foo.com^"); 235 checkMatch(test, ["@@||foo.com^"], "http://foo.com/bar", "IMAGE", "foo.com", n ull, false, null, "@@||foo.com^");
239 checkMatch(test, ["/bar", "@@||foo.com^"], "http://foo.com/bar", "IMAGE", "foo .com", false, null, false, "@@||foo.com^"); 236 checkMatch(test, ["/bar", "@@||foo.com^"], "http://foo.com/bar", "IMAGE", "foo .com", null, false, "@@||foo.com^");
240 checkMatch(test, ["/bar", "@@||foo.com^"], "http://foo.com/foo", "IMAGE", "foo .com", false, null, false, null, "@@||foo.com^"); 237 checkMatch(test, ["/bar", "@@||foo.com^"], "http://foo.com/foo", "IMAGE", "foo .com", null, false, null, "@@||foo.com^");
241 checkMatch(test, ["||foo.com^$popup"], "http://foo.com/bar", "POPUP", "foo.com ", false, null, false, "||foo.com^$popup"); 238 checkMatch(test, ["||foo.com^$popup"], "http://foo.com/bar", "POPUP", "foo.com ", null, false, "||foo.com^$popup");
242 checkMatch(test, ["@@||foo.com^$popup"], "http://foo.com/bar", "POPUP", "foo.c om", false, null, false, null, "@@||foo.com^$popup"); 239 checkMatch(test, ["@@||foo.com^$popup"], "http://foo.com/bar", "POPUP", "foo.c om", null, false, null, "@@||foo.com^$popup");
243 checkMatch(test, ["||foo.com^$popup", "@@||foo.com^$popup"], "http://foo.com/b ar", "POPUP", "foo.com", false, null, false, "@@||foo.com^$popup", "||foo.com^$p opup"); 240 checkMatch(test, ["||foo.com^$popup", "@@||foo.com^$popup"], "http://foo.com/b ar", "POPUP", "foo.com", null, false, "@@||foo.com^$popup", "||foo.com^$popup");
244 checkMatch(test, ["||foo.com^$csp=script-src 'none'"], "http://foo.com/bar", " CSP", "foo.com", false, null, false, "||foo.com^$csp=script-src 'none'"); 241 checkMatch(test, ["||foo.com^$csp=script-src 'none'"], "http://foo.com/bar", " CSP", "foo.com", null, false, "||foo.com^$csp=script-src 'none'");
245 checkMatch(test, ["@@||foo.com^$csp"], "http://foo.com/bar", "CSP", "foo.com", false, null, false, null, "@@||foo.com^$csp"); 242 checkMatch(test, ["@@||foo.com^$csp"], "http://foo.com/bar", "CSP", "foo.com", null, false, null, "@@||foo.com^$csp");
246 checkMatch(test, ["||foo.com^$csp=script-src 'none'", "@@||foo.com^$csp"], "ht tp://foo.com/bar", "CSP", "foo.com", false, null, false, "@@||foo.com^$csp", "|| foo.com^$csp=script-src 'none'"); 243 checkMatch(test, ["||foo.com^$csp=script-src 'none'", "@@||foo.com^$csp"], "ht tp://foo.com/bar", "CSP", "foo.com", null, false, "@@||foo.com^$csp", "||foo.com ^$csp=script-src 'none'");
247 244
248 test.done(); 245 test.done();
249 }; 246 };
250 247
251 exports.testFilterSearch = function(test) 248 exports.testFilterSearch = function(test)
252 { 249 {
253 // Start with three filters: foo, bar, and @@foo 250 // Start with three filters: foo, bar, and @@foo
254 let filters = ["foo", "bar", "@@foo"]; 251 let filters = ["foo", "bar", "@@foo"];
255 252
256 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com", 253 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com",
257 false, null, false, "all", 254 null, false, "all",
258 {blocking: ["foo"], whitelist: ["@@foo"]}); 255 {blocking: ["foo"], whitelist: ["@@foo"]});
259 256
260 // Blocking only. 257 // Blocking only.
261 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com", 258 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com",
262 false, null, false, "blocking", {blocking: ["foo"]}); 259 null, false, "blocking", {blocking: ["foo"]});
263 260
264 // Whitelist only. 261 // Whitelist only.
265 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com", 262 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com",
266 false, null, false, "whitelist", {whitelist: ["@@foo"]}); 263 null, false, "whitelist", {whitelist: ["@@foo"]});
267 264
268 // Different URLs. 265 // Different URLs.
269 checkSearch(test, filters, "http://example.com/bar", "IMAGE", "example.com", 266 checkSearch(test, filters, "http://example.com/bar", "IMAGE", "example.com",
270 false, null, false, "all", {blocking: ["bar"], whitelist: []}); 267 null, false, "all", {blocking: ["bar"], whitelist: []});
271 checkSearch(test, filters, "http://example.com/foo/bar", "IMAGE", 268 checkSearch(test, filters, "http://example.com/foo/bar", "IMAGE",
272 "example.com", false, null, false, "all", 269 "example.com", null, false, "all",
273 {blocking: ["foo", "bar"], whitelist: ["@@foo"]}); 270 {blocking: ["foo", "bar"], whitelist: ["@@foo"]});
274 271
275 // Non-matching content type. 272 // Non-matching content type.
276 checkSearch(test, filters, "http://example.com/foo", "CSP", "example.com", 273 checkSearch(test, filters, "http://example.com/foo", "CSP", "example.com",
277 false, null, false, "all", {blocking: [], whitelist: []}); 274 null, false, "all", {blocking: [], whitelist: []});
278 275
279 // Non-matching specificity. 276 // Non-matching specificity.
280 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com", 277 checkSearch(test, filters, "http://example.com/foo", "IMAGE", "example.com",
281 false, null, true, "all", {blocking: [], whitelist: ["@@foo"]}); 278 null, true, "all", {blocking: [], whitelist: ["@@foo"]});
282 279
283 test.done(); 280 test.done();
284 }; 281 };
285 282
286 exports.testResultCacheChecks = function(test) 283 exports.testResultCacheChecks = function(test)
287 { 284 {
288 let matcher = new CombinedMatcher(); 285 let matcher = new CombinedMatcher();
289 matcher.add(Filter.fromText("abc$image")); 286 matcher.add(Filter.fromText("abc$image"));
290 matcher.add(Filter.fromText("abc$script")); 287 matcher.add(Filter.fromText("abc$script"));
291 matcher.add(Filter.fromText("abc$~image,~script,~media,~ping")); 288 matcher.add(Filter.fromText("abc$~image,~script,~media,~ping"));
292 matcher.add(Filter.fromText("cba$third-party")); 289 matcher.add(Filter.fromText("cba$third-party"));
293 matcher.add(Filter.fromText("cba$~third-party,~script")); 290 matcher.add(Filter.fromText("cba$~third-party,~script"));
294 matcher.add(Filter.fromText("http://def$image")); 291 matcher.add(Filter.fromText("http://def$image"));
295 matcher.add(Filter.fromText("http://def$script")); 292 matcher.add(Filter.fromText("http://def$script"));
296 matcher.add(Filter.fromText("http://def$~image,~script,~media,~ping")); 293 matcher.add(Filter.fromText("http://def$~image,~script,~media,~ping"));
297 matcher.add(Filter.fromText("http://fed$third-party")); 294 matcher.add(Filter.fromText("http://fed$third-party"));
298 matcher.add(Filter.fromText("http://fed$~third-party,~script")); 295 matcher.add(Filter.fromText("http://fed$~third-party,~script"));
299 296
300 cacheCheck(test, matcher, "http://abc", "IMAGE", null, false, "abc$image"); 297 cacheCheck(test, matcher, "http://abc", "IMAGE", "abc", "abc$image");
301 cacheCheck(test, matcher, "http://abc", "SCRIPT", null, false, "abc$script"); 298 cacheCheck(test, matcher, "http://abc", "SCRIPT", "abc", "abc$script");
302 cacheCheck(test, matcher, "http://abc", "OTHER", null, false, "abc$~image,~scr ipt,~media,~ping"); 299 cacheCheck(test, matcher, "http://abc", "OTHER", "abc", "abc$~image,~script,~m edia,~ping");
303 cacheCheck(test, matcher, "http://cba", "IMAGE", null, false, "cba$~third-part y,~script"); 300 cacheCheck(test, matcher, "http://cba", "IMAGE", "cba", "cba$~third-party,~scr ipt");
304 cacheCheck(test, matcher, "http://cba", "IMAGE", null, true, "cba$third-party" ); 301 cacheCheck(test, matcher, "http://cba", "IMAGE", "third-party-domain", "cba$th ird-party");
305 cacheCheck(test, matcher, "http://def", "IMAGE", null, false, "http://def$imag e"); 302 cacheCheck(test, matcher, "http://def", "IMAGE", "def", "http://def$image");
306 cacheCheck(test, matcher, "http://def", "SCRIPT", null, false, "http://def$scr ipt"); 303 cacheCheck(test, matcher, "http://def", "SCRIPT", "def", "http://def$script");
307 cacheCheck(test, matcher, "http://def", "OTHER", null, false, "http://def$~ima ge,~script,~media,~ping"); 304 cacheCheck(test, matcher, "http://def", "OTHER", "def", "http://def$~image,~sc ript,~media,~ping");
308 cacheCheck(test, matcher, "http://fed", "IMAGE", null, false, "http://fed$~thi rd-party,~script"); 305 cacheCheck(test, matcher, "http://fed", "IMAGE", "fed", "http://fed$~third-par ty,~script");
309 cacheCheck(test, matcher, "http://fed", "IMAGE", null, true, "http://fed$third -party"); 306 cacheCheck(test, matcher, "http://fed", "IMAGE", "third-party-domain", "http:/ /fed$third-party");
310 cacheCheck(test, matcher, "http://abc_cba", "MEDIA", null, false, "cba$~third- party,~script"); 307 cacheCheck(test, matcher, "http://abc_cba", "MEDIA", "abc_cba", "cba$~third-pa rty,~script");
311 cacheCheck(test, matcher, "http://abc_cba", "MEDIA", null, true, "cba$third-pa rty"); 308 cacheCheck(test, matcher, "http://abc_cba", "MEDIA", "third-party-domain", "cb a$third-party");
312 cacheCheck(test, matcher, "http://abc_cba", "SCRIPT", null, false, "abc$script "); 309 cacheCheck(test, matcher, "http://abc_cba", "SCRIPT", "abc_cba", "abc$script") ;
313 cacheCheck(test, matcher, "http://def?http://fed", "MEDIA", null, false, "http ://fed$~third-party,~script"); 310 cacheCheck(test, matcher, "http://def?http://fed", "MEDIA", "def", "http://fed $~third-party,~script");
314 cacheCheck(test, matcher, "http://def?http://fed", "MEDIA", null, true, "http: //fed$third-party"); 311 cacheCheck(test, matcher, "http://def?http://fed", "MEDIA", "third-party-domai n", "http://fed$third-party");
315 cacheCheck(test, matcher, "http://def?http://fed", "SCRIPT", null, false, "htt p://def$script"); 312 cacheCheck(test, matcher, "http://def?http://fed", "SCRIPT", "def", "http://de f$script");
316 313
317 test.done(); 314 test.done();
318 }; 315 };
319 316
320 exports.testWhitelisted = function(test) 317 exports.testWhitelisted = function(test)
321 { 318 {
322 let matcher = new CombinedMatcher(); 319 let matcher = new CombinedMatcher();
323 320
324 test.ok(!matcher.isWhitelisted("https://example.com/foo", 321 test.ok(!matcher.isWhitelisted("https://example.com/foo",
325 RegExpFilter.typeMap.IMAGE)); 322 RegExpFilter.typeMap.IMAGE));
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
363 RegExpFilter.typeMap.IMAGE)); 360 RegExpFilter.typeMap.IMAGE));
364 361
365 matcher.remove(Filter.fromText("||example.com/foo/bar/image.jpg")); 362 matcher.remove(Filter.fromText("||example.com/foo/bar/image.jpg"));
366 363
367 // Make sure the filter got removed so there is no match. 364 // Make sure the filter got removed so there is no match.
368 test.ok(!matcher.matchesAny("https://example.com/foo/bar/image.jpg", 365 test.ok(!matcher.matchesAny("https://example.com/foo/bar/image.jpg",
369 RegExpFilter.typeMap.IMAGE)); 366 RegExpFilter.typeMap.IMAGE));
370 367
371 test.done(); 368 test.done();
372 }; 369 };
OLDNEW
« lib/matcher.js ('K') | « lib/matcher.js ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld