gecko-dev/netwerk/test/unit/test_bug826063.js
Ehsan Akhgari 868c13b5e5 Bug 1547397 - Part 2: Move some xpcshell tests for cookies out of extensions/cookies; r=baku
Differential Revision: https://phabricator.services.mozilla.com/D29115

--HG--
rename : extensions/cookie/test/unit/head_cookies.js => netwerk/test/unit/head_cookies.js
rename : extensions/cookie/test/unit/test_bug526789.js => netwerk/test/unit/test_bug526789.js
rename : extensions/cookie/test/unit/test_bug650522.js => netwerk/test/unit/test_bug650522.js
rename : extensions/cookie/test/unit/test_bug667087.js => netwerk/test/unit/test_bug667087.js
rename : extensions/cookie/test/unit/test_cookies_async_failure.js => netwerk/test/unit/test_cookies_async_failure.js
rename : extensions/cookie/test/unit/test_cookies_persistence.js => netwerk/test/unit/test_cookies_persistence.js
rename : extensions/cookie/test/unit/test_cookies_privatebrowsing.js => netwerk/test/unit/test_cookies_privatebrowsing.js
rename : extensions/cookie/test/unit/test_cookies_profile_close.js => netwerk/test/unit/test_cookies_profile_close.js
rename : extensions/cookie/test/unit/test_cookies_read.js => netwerk/test/unit/test_cookies_read.js
rename : extensions/cookie/test/unit/test_cookies_sync_failure.js => netwerk/test/unit/test_cookies_sync_failure.js
rename : extensions/cookie/test/unit/test_cookies_thirdparty.js => netwerk/test/unit/test_cookies_thirdparty.js
rename : extensions/cookie/test/unit/test_cookies_thirdparty_nonsecure_session.js => netwerk/test/unit/test_cookies_thirdparty_nonsecure_session.js
rename : extensions/cookie/test/unit/test_cookies_thirdparty_session.js => netwerk/test/unit/test_cookies_thirdparty_session.js
rename : extensions/cookie/test/unit/test_domain_eviction.js => netwerk/test/unit/test_domain_eviction.js
rename : extensions/cookie/test/unit/test_eviction.js => netwerk/test/unit/test_eviction.js
rename : extensions/cookie/test/unit/test_schema_2_migration.js => netwerk/test/unit/test_schema_2_migration.js
rename : extensions/cookie/test/unit/test_schema_3_migration.js => netwerk/test/unit/test_schema_3_migration.js
extra : moz-landing-system : lando
2019-04-30 14:06:27 +00:00

96 lines
2 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
*/
var URIs = [
"http://example.org",
"https://example.org",
"ftp://example.org"
];
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 = Cu.createPrivateLoadContext();
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 = Cu.createLoadContext();
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();
}