mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-11-12 22:28:59 +02:00
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
117 lines
3 KiB
JavaScript
117 lines
3 KiB
JavaScript
const {HttpServer} = ChromeUtils.import("resource://testing-common/httpd.js");
|
|
|
|
XPCOMUtils.defineLazyGetter(this, "URL", function() {
|
|
return "http://localhost:" + httpserv.identity.primaryPort;
|
|
});
|
|
|
|
// This unit test ensures connections with different tlsFlags have their own
|
|
// connection pool. We verify this behavior by opening channels with different
|
|
// tlsFlags, and their connection info's hash keys should be different.
|
|
|
|
// In the first round of this test, we record the hash key for each connection.
|
|
// In the second round, we check if each connection's hash key is consistent
|
|
// and different from other connection's hash key.
|
|
|
|
let httpserv = null;
|
|
let gSecondRoundStarted = false;
|
|
|
|
let randomFlagValues = [
|
|
0x00000000,
|
|
|
|
0xFFFFFFFF,
|
|
|
|
0x12345678,
|
|
0x12345678,
|
|
|
|
0x11111111,
|
|
0x22222222,
|
|
|
|
0xAAAAAAAA,
|
|
0x77777777,
|
|
|
|
0xBBBBBBBB,
|
|
0xCCCCCCCC
|
|
];
|
|
|
|
function handler(metadata, response) {
|
|
response.setHeader("Content-Type", "text/plain", false);
|
|
response.setHeader("Cache-Control", "no-cache", false);
|
|
response.setStatusLine(metadata.httpVersion, 200, "OK");
|
|
let body = "0123456789";
|
|
response.bodyOutputStream.write(body, body.length);
|
|
}
|
|
|
|
function makeChan(url, tlsFlags) {
|
|
let chan = NetUtil.newChannel({ uri: url, loadUsingSystemPrincipal: true });
|
|
chan.QueryInterface(Ci.nsIHttpChannelInternal);
|
|
chan.tlsFlags = tlsFlags;
|
|
|
|
return chan;
|
|
}
|
|
|
|
let previousHashKeys = {};
|
|
|
|
function Listener(tlsFlags) {
|
|
this.tlsFlags = tlsFlags;
|
|
}
|
|
|
|
let gTestsRun = 0;
|
|
Listener.prototype = {
|
|
onStartRequest: function(request) {
|
|
request.QueryInterface(Ci.nsIHttpChannel)
|
|
.QueryInterface(Ci.nsIHttpChannelInternal);
|
|
|
|
Assert.equal(request.tlsFlags, this.tlsFlags);
|
|
|
|
let hashKey = request.connectionInfoHashKey;
|
|
if (gSecondRoundStarted) {
|
|
// Compare the hash keys with the previous set ones.
|
|
// Hash keys should match if and only if their tlsFlags are the same.
|
|
for (let tlsFlags of randomFlagValues) {
|
|
if (tlsFlags == this.tlsFlags) {
|
|
Assert.equal(hashKey, previousHashKeys[tlsFlags]);
|
|
} else {
|
|
Assert.notEqual(hashKey, previousHashKeys[tlsFlags]);
|
|
}
|
|
}
|
|
} else {
|
|
// Set the hash keys in the first round.
|
|
previousHashKeys[this.tlsFlags] = hashKey;
|
|
}
|
|
},
|
|
onDataAvailable: function(request, stream, off, cnt) {
|
|
read_stream(stream, cnt);
|
|
},
|
|
onStopRequest: function() {
|
|
gTestsRun++;
|
|
if (gTestsRun == randomFlagValues.length) {
|
|
gTestsRun = 0;
|
|
if (gSecondRoundStarted) {
|
|
// The second round finishes.
|
|
httpserv.stop(do_test_finished);
|
|
} else {
|
|
// The first round finishes. Do the second round.
|
|
gSecondRoundStarted = true;
|
|
doTest();
|
|
}
|
|
}
|
|
},
|
|
};
|
|
|
|
function doTest() {
|
|
for (let tlsFlags of randomFlagValues) {
|
|
let chan = makeChan(URL, tlsFlags);
|
|
let listener = new Listener(tlsFlags);
|
|
chan.asyncOpen(listener);
|
|
}
|
|
}
|
|
|
|
function run_test() {
|
|
do_test_pending();
|
|
httpserv = new HttpServer();
|
|
httpserv.registerPathHandler("/", handler);
|
|
httpserv.start(-1);
|
|
|
|
doTest();
|
|
}
|
|
|