Index: test/domainRestrictions.js |
=================================================================== |
--- a/test/domainRestrictions.js |
+++ b/test/domainRestrictions.js |
@@ -12,202 +12,197 @@ |
* GNU General Public License for more details. |
* |
* You should have received a copy of the GNU General Public License |
* along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
*/ |
"use strict"; |
+const assert = require("assert"); |
const {createSandbox} = require("./_common"); |
let Filter = null; |
-exports.setUp = function(callback) |
-{ |
- let sandboxedRequire = createSandbox(); |
- ( |
- {Filter} = sandboxedRequire("../lib/filterClasses") |
- ); |
- |
- callback(); |
-}; |
- |
-function testActive(test, text, domain, expectedActive, expectedOnlyDomain) |
-{ |
- let filter = Filter.fromText(text); |
- test.equal(filter.isActiveOnDomain(domain), expectedActive, |
- text + " active on " + domain); |
- test.equal(filter.isActiveOnlyOnDomain(domain), expectedOnlyDomain, |
- text + " only active on " + domain); |
-} |
- |
-exports.testUnrestrictedBlockingFilters = function(test) |
-{ |
- testActive(test, "foo", null, true, false); |
- testActive(test, "foo", "com", true, false); |
- testActive(test, "foo", "example.com", true, false); |
- testActive(test, "foo", "example.com.", true, false); |
- testActive(test, "foo", "foo.example.com", true, false); |
- testActive(test, "foo", "mple.com", true, false); |
- |
- test.done(); |
-}; |
- |
-exports.testUnrestrictedHidingRules = function(test) |
-{ |
- testActive(test, "##foo", null, true, false); |
- testActive(test, "##foo", "com", true, false); |
- testActive(test, "##foo", "example.com", true, false); |
- testActive(test, "##foo", "example.com.", true, false); |
- testActive(test, "##foo", "foo.example.com", true, false); |
- testActive(test, "##foo", "mple.com", true, false); |
- |
- test.done(); |
-}; |
- |
-exports.testDomainRestrictedBlockingFilters = function(test) |
+describe("Domain Restrictions", () => |
{ |
- testActive(test, "foo$domain=example.com", null, false, false); |
- testActive(test, "foo$domain=example.com", "com", false, true); |
- testActive(test, "foo$domain=example.com", "example.com", true, true); |
- testActive(test, "foo$domain=example.com", "example.com.", true, true); |
- testActive(test, "foo$domain=example.com.", "example.com", false, false); |
- testActive(test, "foo$domain=example.com.", "example.com.", false, false); |
- testActive(test, "foo$domain=example.com", "foo.example.com", true, false); |
- testActive(test, "foo$domain=example.com", "mple.com", false, false); |
+ beforeEach(() => |
+ { |
+ let sandboxedRequire = createSandbox(); |
+ ( |
+ {Filter} = sandboxedRequire("../lib/filterClasses") |
+ ); |
+ }); |
+ |
+ function testActive(text, domain, expectedActive, expectedOnlyDomain) |
+ { |
+ let filter = Filter.fromText(text); |
+ assert.equal(filter.isActiveOnDomain(domain), expectedActive, |
+ text + " active on " + domain); |
+ assert.equal(filter.isActiveOnlyOnDomain(domain), expectedOnlyDomain, |
+ text + " only active on " + domain); |
+ } |
- test.done(); |
-}; |
+ describe("Unrestricted", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo", null, true, false); |
+ testActive("foo", "com", true, false); |
+ testActive("foo", "example.com", true, false); |
+ testActive("foo", "example.com.", true, false); |
+ testActive("foo", "foo.example.com", true, false); |
+ testActive("foo", "mple.com", true, false); |
+ }); |
-exports.testDomainRestrictedHidingRules = function(test) |
-{ |
- testActive(test, "example.com##foo", null, false, false); |
- testActive(test, "example.com##foo", "com", false, true); |
- testActive(test, "example.com##foo", "example.com", true, true); |
- testActive(test, "example.com##foo", "example.com.", true, true); |
- testActive(test, "example.com.##foo", "example.com", false, false); |
- testActive(test, "example.com.##foo", "example.com.", false, false); |
- testActive(test, "example.com##foo", "foo.example.com", true, false); |
- testActive(test, "example.com##foo", "mple.com", false, false); |
+ it("Hiding Rules", () => |
+ { |
+ testActive("##foo", null, true, false); |
+ testActive("##foo", "com", true, false); |
+ testActive("##foo", "example.com", true, false); |
+ testActive("##foo", "example.com.", true, false); |
+ testActive("##foo", "foo.example.com", true, false); |
+ testActive("##foo", "mple.com", true, false); |
+ }); |
+ }); |
- test.done(); |
-}; |
- |
-exports.testBlockingFiltersRestrictedToDomainAndItsSubdomain = function(test) |
-{ |
- testActive(test, "foo$domain=example.com|foo.example.com", null, false, false); |
- testActive(test, "foo$domain=example.com|foo.example.com", "com", false, true); |
- testActive(test, "foo$domain=example.com|foo.example.com", "example.com", true, true); |
- testActive(test, "foo$domain=example.com|foo.example.com", "example.com.", true, true); |
- testActive(test, "foo$domain=example.com|foo.example.com", "foo.example.com", true, false); |
- testActive(test, "foo$domain=example.com|foo.example.com", "mple.com", false, false); |
+ describe("Domain Restricted", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo$domain=example.com", null, false, false); |
+ testActive("foo$domain=example.com", "com", false, true); |
+ testActive("foo$domain=example.com", "example.com", true, true); |
+ testActive("foo$domain=example.com", "example.com.", true, true); |
+ testActive("foo$domain=example.com.", "example.com", false, false); |
+ testActive("foo$domain=example.com.", "example.com.", false, false); |
+ testActive("foo$domain=example.com", "foo.example.com", true, false); |
+ testActive("foo$domain=example.com", "mple.com", false, false); |
+ }); |
- test.done(); |
-}; |
+ it("Hiding Rules", () => |
+ { |
+ testActive("example.com##foo", null, false, false); |
+ testActive("example.com##foo", "com", false, true); |
+ testActive("example.com##foo", "example.com", true, true); |
+ testActive("example.com##foo", "example.com.", true, true); |
+ testActive("example.com.##foo", "example.com", false, false); |
+ testActive("example.com.##foo", "example.com.", false, false); |
+ testActive("example.com##foo", "foo.example.com", true, false); |
+ testActive("example.com##foo", "mple.com", false, false); |
+ }); |
+ }); |
-exports.testHidingRulesRestrictedToDomainAndItsSubdomain = function(test) |
-{ |
- testActive(test, "example.com,foo.example.com##foo", null, false, false); |
- testActive(test, "example.com,foo.example.com##foo", "com", false, true); |
- testActive(test, "example.com,foo.example.com##foo", "example.com", true, true); |
- testActive(test, "example.com,foo.example.com##foo", "example.com.", true, true); |
- testActive(test, "example.com,foo.example.com##foo", "foo.example.com", true, false); |
- testActive(test, "example.com,foo.example.com##foo", "mple.com", false, false); |
+ describe("Restricted to Domain and its Subdomain", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo$domain=example.com|foo.example.com", null, false, false); |
+ testActive("foo$domain=example.com|foo.example.com", "com", false, true); |
+ testActive("foo$domain=example.com|foo.example.com", "example.com", true, true); |
+ testActive("foo$domain=example.com|foo.example.com", "example.com.", true, true); |
+ testActive("foo$domain=example.com|foo.example.com", "foo.example.com", true, false); |
+ testActive("foo$domain=example.com|foo.example.com", "mple.com", false, false); |
+ }); |
- test.done(); |
-}; |
+ it("Hiding Rules", () => |
+ { |
+ testActive("example.com,foo.example.com##foo", null, false, false); |
+ testActive("example.com,foo.example.com##foo", "com", false, true); |
+ testActive("example.com,foo.example.com##foo", "example.com", true, true); |
+ testActive("example.com,foo.example.com##foo", "example.com.", true, true); |
+ testActive("example.com,foo.example.com##foo", "foo.example.com", true, false); |
+ testActive("example.com,foo.example.com##foo", "mple.com", false, false); |
+ }); |
+ }); |
-exports.testBlockingFiltersWithExceptionForASubdomain = function(test) |
-{ |
- testActive(test, "foo$domain=~foo.example.com", null, true, false); |
- testActive(test, "foo$domain=~foo.example.com", "com", true, false); |
- testActive(test, "foo$domain=~foo.example.com", "example.com", true, false); |
- testActive(test, "foo$domain=~foo.example.com", "example.com.", true, false); |
- testActive(test, "foo$domain=~foo.example.com", "foo.example.com", false, false); |
- testActive(test, "foo$domain=~foo.example.com", "mple.com", true, false); |
- |
- test.done(); |
-}; |
+ describe("With Exception For a Subdomain", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo$domain=~foo.example.com", null, true, false); |
+ testActive("foo$domain=~foo.example.com", "com", true, false); |
+ testActive("foo$domain=~foo.example.com", "example.com", true, false); |
+ testActive("foo$domain=~foo.example.com", "example.com.", true, false); |
+ testActive("foo$domain=~foo.example.com", "foo.example.com", false, false); |
+ testActive("foo$domain=~foo.example.com", "mple.com", true, false); |
+ }); |
-exports.testHidingRulesWithExceptionForASubdomain = function(test) |
-{ |
- testActive(test, "~foo.example.com##foo", null, true, false); |
- testActive(test, "~foo.example.com##foo", "com", true, false); |
- testActive(test, "~foo.example.com##foo", "example.com", true, false); |
- testActive(test, "~foo.example.com##foo", "example.com.", true, false); |
- testActive(test, "~foo.example.com##foo", "foo.example.com", false, false); |
- testActive(test, "~foo.example.com##foo", "mple.com", true, false); |
- |
- test.done(); |
-}; |
+ it("Hiding Rules", () => |
+ { |
+ testActive("~foo.example.com##foo", null, true, false); |
+ testActive("~foo.example.com##foo", "com", true, false); |
+ testActive("~foo.example.com##foo", "example.com", true, false); |
+ testActive("~foo.example.com##foo", "example.com.", true, false); |
+ testActive("~foo.example.com##foo", "foo.example.com", false, false); |
+ testActive("~foo.example.com##foo", "mple.com", true, false); |
+ }); |
+ }); |
-exports.testBlockingFiltersForDomainButNotItsSubdomain = function(test) |
-{ |
- testActive(test, "foo$domain=example.com|~foo.example.com", null, false, false); |
- testActive(test, "foo$domain=example.com|~foo.example.com", "com", false, true); |
- testActive(test, "foo$domain=example.com|~foo.example.com", "example.com", true, true); |
- testActive(test, "foo$domain=example.com|~foo.example.com", "example.com.", true, true); |
- testActive(test, "foo$domain=example.com|~foo.example.com", "foo.example.com", false, false); |
- testActive(test, "foo$domain=example.com|~foo.example.com", "mple.com", false, false); |
- |
- test.done(); |
-}; |
+ describe("For Domain but not its Subdomain", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo$domain=example.com|~foo.example.com", null, false, false); |
+ testActive("foo$domain=example.com|~foo.example.com", "com", false, true); |
+ testActive("foo$domain=example.com|~foo.example.com", "example.com", true, true); |
+ testActive("foo$domain=example.com|~foo.example.com", "example.com.", true, true); |
+ testActive("foo$domain=example.com|~foo.example.com", "foo.example.com", false, false); |
+ testActive("foo$domain=example.com|~foo.example.com", "mple.com", false, false); |
+ }); |
-exports.testHidingRulesForDomainButNotItsSubdomain = function(test) |
-{ |
- testActive(test, "example.com,~foo.example.com##foo", null, false, false); |
- testActive(test, "example.com,~foo.example.com##foo", "com", false, true); |
- testActive(test, "example.com,~foo.example.com##foo", "example.com", true, true); |
- testActive(test, "example.com,~foo.example.com##foo", "example.com.", true, true); |
- testActive(test, "example.com,~foo.example.com##foo", "foo.example.com", false, false); |
- testActive(test, "example.com,~foo.example.com##foo", "mple.com", false, false); |
- |
- test.done(); |
-}; |
+ it("Hiding Rules", () => |
+ { |
+ testActive("example.com,~foo.example.com##foo", null, false, false); |
+ testActive("example.com,~foo.example.com##foo", "com", false, true); |
+ testActive("example.com,~foo.example.com##foo", "example.com", true, true); |
+ testActive("example.com,~foo.example.com##foo", "example.com.", true, true); |
+ testActive("example.com,~foo.example.com##foo", "foo.example.com", false, false); |
+ testActive("example.com,~foo.example.com##foo", "mple.com", false, false); |
+ }); |
+ }); |
-exports.testBlockingFiltersForDomainButNotItsTLD = function(test) |
-{ |
- testActive(test, "foo$domain=example.com|~com", null, false, false); |
- testActive(test, "foo$domain=example.com|~com", "com", false, true); |
- testActive(test, "foo$domain=example.com|~com", "example.com", true, true); |
- testActive(test, "foo$domain=example.com|~com", "example.com.", true, true); |
- testActive(test, "foo$domain=example.com|~com", "foo.example.com", true, false); |
- testActive(test, "foo$domain=example.com|~com", "mple.com", false, false); |
- |
- test.done(); |
-}; |
+ describe("For Domain but not its TLD", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo$domain=example.com|~com", null, false, false); |
+ testActive("foo$domain=example.com|~com", "com", false, true); |
+ testActive("foo$domain=example.com|~com", "example.com", true, true); |
+ testActive("foo$domain=example.com|~com", "example.com.", true, true); |
+ testActive("foo$domain=example.com|~com", "foo.example.com", true, false); |
+ testActive("foo$domain=example.com|~com", "mple.com", false, false); |
+ }); |
-exports.testHidingRulesForDomainButNotItsTLD = function(test) |
-{ |
- testActive(test, "example.com,~com##foo", null, false, false); |
- testActive(test, "example.com,~com##foo", "com", false, true); |
- testActive(test, "example.com,~com##foo", "example.com", true, true); |
- testActive(test, "example.com,~com##foo", "example.com.", true, true); |
- testActive(test, "example.com,~com##foo", "foo.example.com", true, false); |
- testActive(test, "example.com,~com##foo", "mple.com", false, false); |
- |
- test.done(); |
-}; |
+ it("Hiding Rules", () => |
+ { |
+ testActive("example.com,~com##foo", null, false, false); |
+ testActive("example.com,~com##foo", "com", false, true); |
+ testActive("example.com,~com##foo", "example.com", true, true); |
+ testActive("example.com,~com##foo", "example.com.", true, true); |
+ testActive("example.com,~com##foo", "foo.example.com", true, false); |
+ testActive("example.com,~com##foo", "mple.com", false, false); |
+ }); |
+ }); |
-exports.testBlockingFiltersRestrictedToAnUnrelatedDomain = function(test) |
-{ |
- testActive(test, "foo$domain=nnnnnnn.nnn", null, false, false); |
- testActive(test, "foo$domain=nnnnnnn.nnn", "com", false, false); |
- testActive(test, "foo$domain=nnnnnnn.nnn", "example.com", false, false); |
- testActive(test, "foo$domain=nnnnnnn.nnn", "example.com.", false, false); |
- testActive(test, "foo$domain=nnnnnnn.nnn", "foo.example.com", false, false); |
- testActive(test, "foo$domain=nnnnnnn.nnn", "mple.com", false, false); |
- |
- test.done(); |
-}; |
+ describe("Restricted To An Unrelated Domain", () => |
+ { |
+ it("Blocking Filters", () => |
+ { |
+ testActive("foo$domain=nnnnnnn.nnn", null, false, false); |
+ testActive("foo$domain=nnnnnnn.nnn", "com", false, false); |
+ testActive("foo$domain=nnnnnnn.nnn", "example.com", false, false); |
+ testActive("foo$domain=nnnnnnn.nnn", "example.com.", false, false); |
+ testActive("foo$domain=nnnnnnn.nnn", "foo.example.com", false, false); |
+ testActive("foo$domain=nnnnnnn.nnn", "mple.com", false, false); |
+ }); |
-exports.testHidingRulesRestrictedToAnUnrelatedDomain = function(test) |
-{ |
- testActive(test, "nnnnnnn.nnn##foo", null, false, false); |
- testActive(test, "nnnnnnn.nnn##foo", "com", false, false); |
- testActive(test, "nnnnnnn.nnn##foo", "example.com", false, false); |
- testActive(test, "nnnnnnn.nnn##foo", "example.com.", false, false); |
- testActive(test, "nnnnnnn.nnn##foo", "foo.example.com", false, false); |
- testActive(test, "nnnnnnn.nnn##foo", "mple.com", false, false); |
- |
- test.done(); |
-}; |
+ it("Hiding Rules", () => |
+ { |
+ testActive("nnnnnnn.nnn##foo", null, false, false); |
+ testActive("nnnnnnn.nnn##foo", "com", false, false); |
+ testActive("nnnnnnn.nnn##foo", "example.com", false, false); |
+ testActive("nnnnnnn.nnn##foo", "example.com.", false, false); |
+ testActive("nnnnnnn.nnn##foo", "foo.example.com", false, false); |
+ testActive("nnnnnnn.nnn##foo", "mple.com", false, false); |
+ }); |
+ }); |
+}); |