summaryrefslogtreecommitdiffstats
path: root/toolkit/components/enterprisepolicies/tests/browser/browser_policies_enterprise_only.js
blob: c0fd63870ac9769fbf76679f45f8eb8e7329969f (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
59
60
61
62
63
64
65
66
67
68
69
70
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

const PREF_DISALLOW_ENTERPRISE = "browser.policies.testing.disallowEnterprise";

add_task(async function test_enterprise_only_policies() {
  let { Policies } = ChromeUtils.importESModule(
    "resource:///modules/policies/Policies.sys.mjs"
  );

  let normalPolicyRan = false,
    enterprisePolicyRan = false;

  Policies.NormalPolicy = {
    onProfileAfterChange() {
      normalPolicyRan = true;
    },
  };

  Policies.EnterpriseOnlyPolicy = {
    onProfileAfterChange() {
      enterprisePolicyRan = true;
    },
  };

  Services.prefs.setBoolPref(PREF_DISALLOW_ENTERPRISE, true);

  await setupPolicyEngineWithJson(
    // policies.json
    {
      policies: {
        NormalPolicy: true,
        EnterpriseOnlyPolicy: true,
      },
    },

    // custom schema
    {
      properties: {
        NormalPolicy: {
          type: "boolean",
        },

        EnterpriseOnlyPolicy: {
          type: "boolean",
          enterprise_only: true,
        },
      },
    }
  );

  is(
    Services.policies.status,
    Ci.nsIEnterprisePolicies.ACTIVE,
    "Engine is active"
  );
  is(normalPolicyRan, true, "Normal policy ran as expected");
  is(
    enterprisePolicyRan,
    false,
    "Enterprise-only policy was prevented from running"
  );

  // Clean-up
  delete Policies.NormalPolicy;
  delete Policies.EnterpriseOnlyPolicy;
  Services.prefs.clearUserPref(PREF_DISALLOW_ENTERPRISE);
});