| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 | /* 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/. */"use strict";const { Cc, Ci, Cu, Cm, components } = require("chrome");const xulApp = require("sdk/system/xul-app");const self = require("sdk/self");const { Loader, main, unload } = require("toolkit/loader");const loaderOptions = require("@loader/options");const { AddonManager } = Cu.import("resource://gre/modules/AddonManager.jsm", {});exports.testSelf = function(assert) {  // Likewise, we can't assert anything about the full URL, because that  // depends on self.id . We can only assert that it ends in the right  // thing.  var url = self.data.url("test-content-symbiont.js");  assert.equal(typeof(url), "string", "self.data.url('x') returns string");  assert.equal(/\/test-content-symbiont\.js$/.test(url), true);  // Make sure 'undefined' is not in url when no string is provided.  url = self.data.url();  assert.equal(typeof(url), "string", "self.data.url() returns string");  assert.equal(/\/undefined$/.test(url), false);  // When tests are run on just the api-utils package, self.name is  // api-utils. When they're run as 'cfx testall', self.name is testpkgs.  assert.equal(self.name, "addon-sdk", "self.name is addon-sdk");  // loadReason may change here, as we change the way tests addons are installed  // Bug 854937 fixed loadReason and is now install  let testLoadReason = xulApp.versionInRange(xulApp.platformVersion,                                             "23.0a1", "*") ? "install"                                                            : "startup";  assert.equal(self.loadReason, testLoadReason,               "self.loadReason is either startup or install on test runs");  assert.equal(self.isPrivateBrowsingSupported, false,               'usePrivateBrowsing property is false by default');};exports.testSelfID = function(assert, done) {  var self = require("sdk/self");  // We can't assert anything about the ID inside the unit test right now,  // because the ID we get depends upon how the test was invoked. The idea  // is that it is supposed to come from the main top-level package's  // package.json file, from the "id" key.  assert.equal(typeof(self.id), "string", "self.id is a string");  assert.ok(self.id.length > 0);  AddonManager.getAddonByID(self.id, function(addon) {    if (!addon) {      assert.fail("did not find addon with self.id");    }    else {      assert.pass("found addon with self.id");    }    done();  });}exports.testSelfHandlesLackingLoaderOptions = function (assert) {  let root = module.uri.substr(0, module.uri.lastIndexOf('/'));  let uri = root + '/fixtures/loader/self/';  let sdkPath = loaderOptions.paths[''] + 'sdk';  let loader = Loader({ paths: { '': uri, 'sdk': sdkPath }});  let program = main(loader, 'main');  let self = program.self;  assert.pass("No errors thrown when including sdk/self without loader options");  assert.equal(self.isPrivateBrowsingSupported, false,    "safely checks sdk/self.isPrivateBrowsingSupported");  assert.equal(self.packed, false,    "safely checks sdk/self.packed");  unload(loader);};require("sdk/test").run(exports);
 |