Left: | ||
Right: |
LEFT | RIGHT |
---|---|
1 (function() | 1 (function() |
2 { | 2 { |
3 module("CSS property filter", { | 3 module("CSS property filter", { |
4 setup: function() | 4 setup: function() |
5 { | 5 { |
6 prepareFilterComponents.call(this); | 6 prepareFilterComponents.call(this); |
7 preparePrefs.call(this); | 7 preparePrefs.call(this); |
8 }, | 8 }, |
9 teardown: function() | 9 teardown: function() |
10 { | 10 { |
11 restoreFilterComponents.call(this); | 11 restoreFilterComponents.call(this); |
12 restorePrefs.call(this); | 12 restorePrefs.call(this); |
13 } | 13 } |
14 }); | 14 }); |
15 | 15 |
16 function runSelectorTest([text, domain, filters, expected]) | 16 function runSelectorTest([text, domain, filters, expected]) |
17 { | 17 { |
18 for (let filter of filters) | 18 for (let filter of filters) |
19 { | 19 { |
20 filter = Filter.fromText(filter); | 20 filter = Filter.fromText(filter); |
21 if (filter instanceof CSSPropertyFilter) | 21 if (filter instanceof CSSPropertyFilter) |
22 CSSRules.add(filter); | 22 CSSRules.add(filter); |
23 else | 23 else |
24 ElemHide.add(filter); | 24 ElemHide.add(filter); |
Wladimir Palant
2015/11/10 10:49:02
Why add to ElemHide here if you are only testing C
Thomas Greiner
2015/12/03 12:55:19
Because exception rules are still handled by `Elem
| |
25 } | 25 } |
26 | 26 |
27 let selectors = CSSRules.getRulesForDomain(domain); | 27 let result = CSSRules.getRulesForDomain(domain) |
Wladimir Palant
2015/11/10 10:49:02
Note that getRulesForDomain() should return filter
Thomas Greiner
2015/12/03 12:55:19
Done.
| |
28 equal(selectors.sort().join("\n"), expected.sort().join("\n"), text); | 28 .map((filter) => filter.text); |
29 deepEqual(result.sort(), expected.sort(), text); | |
29 | 30 |
30 CSSRules.clear(); | 31 CSSRules.clear(); |
31 ElemHide.clear(); | 32 ElemHide.clear(); |
Wladimir Palant
2015/11/10 10:49:02
You should add a CSSRules.clear() call to prepareF
Thomas Greiner
2015/12/03 12:55:19
I already did.
| |
32 } | 33 } |
33 | 34 |
34 let selectorTests = [ | 35 let selectorTests = [ |
35 ["Return unique selectors from single filter", "www.example.com", ["www.exam ple.com,example.com##[-abp-properties='foo']"], ["[-abp-properties='foo']"]], | 36 ["Ignore generic filters", "example.com", ["##[-abp-properties='foo']", "exa mple.com##[-abp-properties='foo']", "~example.com##[-abp-properties='foo']"], [" example.com##[-abp-properties='foo']"]], |
36 // ["Return unique selectors from multiple filters", "www.example.com", ["ww w.example.com##[-abp-properties='foo']", "other.example.org,www.example.com##[-a bp-properties='foo']"], ["[-abp-properties='foo']"]], | 37 ["Ignore selectors with exceptions", "example.com", ["example.com##[-abp-pro perties='foo']", "example.com##[-abp-properties='bar']", "example.com#@#[-abp-pr operties='foo']"], ["example.com##[-abp-properties='bar']"]], |
Thomas Greiner
2015/08/25 16:11:47
I commented this one out since our current impleme
| |
37 ["Ignore selectors with exceptions", "example.com", ["example.com##[-abp-pro perties='foo']", "example.com##[-abp-properties='bar']", "example.com#@#[-abp-pr operties='foo']"], ["[-abp-properties='bar']"]], | |
38 ["Ignore filters that include parent domain but exclude subdomain", "www.exa mple.com", ["~www.example.com,example.com##[-abp-properties='foo']"], []], | 38 ["Ignore filters that include parent domain but exclude subdomain", "www.exa mple.com", ["~www.example.com,example.com##[-abp-properties='foo']"], []], |
39 ["Ignore filters with parent domain if exception matches subdomain", "www.ex ample.com", ["www.example.com#@#[-abp-properties='foo']", "example.com##[-abp-pr operties='foo']"], []] | 39 ["Ignore filters with parent domain if exception matches subdomain", "www.ex ample.com", ["www.example.com#@#[-abp-properties='foo']", "example.com##[-abp-pr operties='foo']"], []], |
Wladimir Palant
2015/11/10 10:49:02
I'd expect a test here verifying that generic rule
Thomas Greiner
2015/12/03 12:55:20
Done. Added a test for ignoring generic filters.
| |
40 ["Ignore filters for other subdomain", "other.example.com", ["www.example.co m##[-abp-properties='foo']", "other.example.com##[-abp-properties='foo']"], ["ot her.example.com##[-abp-properties='foo']"]] | |
40 ]; | 41 ]; |
41 | 42 |
42 test("Domain restrictions", function() | 43 test("Domain restrictions", function() |
43 { | 44 { |
44 for (let selectorTest of selectorTests) | 45 selectorTests.forEach(runSelectorTest); |
45 runSelectorTest(selectorTest); | |
Wladimir Palant
2015/11/10 10:49:02
selectorTests.forEach(runSelectorTest)?
Thomas Greiner
2015/12/03 12:55:20
Done.
| |
46 }); | 46 }); |
47 | |
48 let testObjectCount = 0; | |
49 function constructTestObject(domain) | |
50 { | |
51 let selector = "filter_" + (++testObjectCount); | |
52 return { | |
53 filter: Filter.fromText(domain + "##" + selector), | |
54 selector: selector | |
55 }; | |
56 } | |
57 | 47 |
58 function compareRules(text, domain, expected) | 48 function compareRules(text, domain, expected) |
59 { | 49 { |
60 let result = CSSRules.getRulesForDomain(domain); | 50 let result = CSSRules.getRulesForDomain(domain) |
51 .map((filter) => filter.text); | |
52 expected = expected.map((filter) => filter.text); | |
61 deepEqual(result.sort(), expected.sort(), text); | 53 deepEqual(result.sort(), expected.sort(), text); |
62 } | 54 } |
63 | 55 |
64 test("CSS property filters container", function() | 56 test("CSS property filters container", function() |
65 { | 57 { |
66 let generic = constructTestObject(""); | 58 let domainFilter = Filter.fromText("example.com##filter1"); |
67 let domain = constructTestObject("example.com"); | 59 let subdomainFilter = Filter.fromText("www.example.com##filter2"); |
68 let subdomain = constructTestObject("www.example.com"); | 60 let otherDomainFilter = Filter.fromText("other.example.com##filter3"); |
69 let otherDomain = constructTestObject("other.example.com"); | |
70 | 61 |
71 CSSRules.add(generic.filter); | 62 CSSRules.add(domainFilter); |
72 CSSRules.add(domain.filter); | 63 CSSRules.add(subdomainFilter); |
73 CSSRules.add(subdomain.filter); | 64 CSSRules.add(otherDomainFilter); |
74 CSSRules.add(otherDomain.filter); | |
75 compareRules("Return all matching filters", "www.example.com", | 65 compareRules("Return all matching filters", "www.example.com", |
76 [generic.selector, domain.selector, subdomain.selector]); | 66 [domainFilter, subdomainFilter]); |
67 | |
68 CSSRules.remove(domainFilter); | |
69 compareRules("Return all matching filters after removing one", | |
70 "www.example.com", [subdomainFilter]); | |
77 | 71 |
78 CSSRules.clear(); | 72 CSSRules.clear(); |
79 CSSRules.add(subdomain.filter); | 73 compareRules("Return no filters after clearing", "www.example.com", []); |
80 CSSRules.add(otherDomain.filter); | |
81 compareRules("Don't match other subdomain", "www.example.com", | |
82 [subdomain.selector]); | |
Wladimir Palant
2015/11/10 10:49:02
This check makes little sense IMHO, it's already c
Thomas Greiner
2015/12/03 12:55:20
Done. Moved this to `selectorTests`.
Generally, t
| |
83 }); | 74 }); |
84 })(); | 75 })(); |
LEFT | RIGHT |