gecko-dev/netwerk/test/unit/test_bug826063.js
Kris Maglione 918ed6c474 Bug 1431533: Part 5a - Auto-rewrite code to use ChromeUtils import methods. r=florian
This was done using the following script:
37e3803c7a/processors/chromeutils-import.jsm

MozReview-Commit-ID: 1Nc3XDu0wGl

--HG--
extra : source : 12fc4dee861c812fd2bd032c63ef17af61800c70
extra : intermediate-source : 34c999fa006bffe8705cf50c54708aa21a962e62
extra : histedit_source : b2be2c5e5d226e6c347312456a6ae339c1e634b0
2018-01-29 15:20:18 -08:00

102 lines
2.3 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
/**
* Test that nsIPrivateBrowsingChannel.isChannelPrivate yields the correct
* result for various combinations of .setPrivate() and nsILoadContexts
*/
ChromeUtils.import("resource://gre/modules/XPCOMUtils.jsm");
ChromeUtils.import("resource://gre/modules/NetUtil.jsm");
var URIs = [
"http://example.org",
"https://example.org",
"ftp://example.org"
];
let LoadContext = Components.Constructor("@mozilla.org/loadcontext;1");
let PrivateLoadContext = Components.Constructor("@mozilla.org/privateloadcontext;1");
function* getChannels() {
for (let u of URIs) {
yield NetUtil.newChannel({
uri: u,
loadUsingSystemPrincipal: true
});
}
}
function checkPrivate(channel, shouldBePrivate) {
Assert.equal(channel.QueryInterface(Ci.nsIPrivateBrowsingChannel).isChannelPrivate,
shouldBePrivate);
}
/**
* Default configuration
* Default is non-private
*/
add_test(function test_plain() {
for (let c of getChannels()) {
checkPrivate(c, false);
}
run_next_test();
});
/**
* Explicitly setPrivate(true), no load context
*/
add_test(function test_setPrivate_private() {
for (let c of getChannels()) {
c.QueryInterface(Ci.nsIPrivateBrowsingChannel).setPrivate(true);
checkPrivate(c, true);
}
run_next_test();
});
/**
* Explicitly setPrivate(false), no load context
*/
add_test(function test_setPrivate_regular() {
for (let c of getChannels()) {
c.QueryInterface(Ci.nsIPrivateBrowsingChannel).setPrivate(false);
checkPrivate(c, false);
}
run_next_test();
});
/**
* Load context mandates private mode
*/
add_test(function test_LoadContextPrivate() {
let ctx = new PrivateLoadContext();
for (let c of getChannels()) {
c.notificationCallbacks = ctx;
checkPrivate(c, true);
}
run_next_test();
});
/**
* Load context mandates regular mode
*/
add_test(function test_LoadContextRegular() {
let ctx = new LoadContext();
for (let c of getChannels()) {
c.notificationCallbacks = ctx;
checkPrivate(c, false);
}
run_next_test();
});
// Do not test simultanous uses of .setPrivate and load context.
// There is little merit in doing so, and combining both will assert in
// Debug builds anyway.
function run_test() {
run_next_test();
}