summaryrefslogtreecommitdiffstats
path: root/toolkit/mozapps/extensions/test/xpcshell/test_bug468528.js
blob: 5e8702eb776dbd478fc510ff14914e3be16cb7f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

const nsIBLS = Components.interfaces.nsIBlocklistService;

var PLUGINS = [{
  // Normal blacklisted plugin, before an invalid regexp
  name: "test_bug468528_1",
  version: "5",
  disabled: false,
  blocklisted: false
},
{
  // Normal blacklisted plugin, with an invalid regexp
  name: "test_bug468528_2",
  version: "5",
  disabled: false,
  blocklisted: false
},
{
  // Normal blacklisted plugin, after an invalid regexp
  name: "test_bug468528_3",
  version: "5",
  disabled: false,
  blocklisted: false
},
{
  // Non-blocklisted plugin
  name: "test_bug468528_4",
  version: "5",
  disabled: false,
  blocklisted: false
}];


function run_test() {
  createAppInfo("xpcshell@tests.mozilla.org", "XPCShell", "1", "1.9");

  // We cannot force the blocklist to update so just copy our test list to the profile
  copyBlocklistToProfile(do_get_file("data/test_bug468528.xml"));

  var blocklist = Components.classes["@mozilla.org/extensions/blocklist;1"]
                            .getService(nsIBLS);

  // blocked (sanity check)
  do_check_true(blocklist.getPluginBlocklistState(PLUGINS[0], "1", "1.9") == nsIBLS.STATE_BLOCKED);

  // not blocked - won't match due to invalid regexp
  do_check_true(blocklist.getPluginBlocklistState(PLUGINS[1], "1", "1.9") == nsIBLS.STATE_NOT_BLOCKED);
  
  // blocked - the invalid regexp for the previous item shouldn't affect this one
  do_check_true(blocklist.getPluginBlocklistState(PLUGINS[2], "1", "1.9") == nsIBLS.STATE_BLOCKED);

  // not blocked - the previous invalid regexp shouldn't act as a wildcard
  do_check_true(blocklist.getPluginBlocklistState(PLUGINS[3], "1", "1.9") == nsIBLS.STATE_NOT_BLOCKED);

}