Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

/* 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";
/* import-globals-from head_cache.js */
/* import-globals-from head_cookies.js */
/* import-globals-from head_channels.js */
/* import-globals-from head_servers.js */
/* import-globals-from head_websocket.js */
// These test should basically match the ones in test_websocket_server.js,
// but with multiple websocket clients making requests on the same server
const certOverrideService = Cc[
"@mozilla.org/security/certoverride;1"
].getService(Ci.nsICertOverrideService);
// setup
add_setup(async function setup() {
// turn off cert checking for these tests
certOverrideService.setDisableAllSecurityChecksAndLetAttackersInterceptMyData(
true
);
});
// append cleanup to cleanup queue
registerCleanupFunction(async () => {
certOverrideService.setDisableAllSecurityChecksAndLetAttackersInterceptMyData(
false
);
Services.prefs.clearUserPref("network.http.http2.websockets");
});
async function spinup_and_check(proxy_kind, ws_kind) {
let ws_h2 = true;
if (ws_kind == NodeWebSocketServer) {
info("not h2 ws");
ws_h2 = false;
}
Services.prefs.setBoolPref("network.http.http2.websockets", ws_h2);
let proxy;
if (proxy_kind) {
proxy = new proxy_kind();
await proxy.start();
registerCleanupFunction(async () => proxy.stop());
}
let wss = new ws_kind();
await wss.start();
registerCleanupFunction(async () => wss.stop());
Assert.notEqual(wss.port(), null);
await wss.registerMessageHandler((data, ws) => {
ws.send(data);
});
let url = `wss://localhost:${wss.port()}`;
let conn1 = new WebSocketConnection();
await conn1.open(url);
let conn2 = new WebSocketConnection();
await conn2.open(url);
conn1.send("msg1");
conn2.send("msg2");
let mess2 = await conn2.receiveMessages();
Assert.deepEqual(mess2, ["msg2"]);
conn1.send("msg1 again");
let mess1 = [];
while (mess1.length < 2) {
// receive could return only the first or both replies.
mess1 = mess1.concat(await conn1.receiveMessages());
}
Assert.deepEqual(mess1, ["msg1", "msg1 again"]);
conn1.close();
conn2.close();
Assert.deepEqual({ status: Cr.NS_OK }, await conn1.finished());
Assert.deepEqual({ status: Cr.NS_OK }, await conn2.finished());
await wss.stop();
if (proxy_kind) {
await proxy.stop();
}
}
// h1.1 direct
async function test_h1_websocket_direct() {
await spinup_and_check(null, NodeWebSocketServer);
}
// h2 direct
async function test_h2_websocket_direct() {
await spinup_and_check(null, NodeWebSocketHttp2Server);
}
// ws h1.1 with secure h1.1 proxy
async function test_h1_ws_with_secure_h1_proxy() {
await spinup_and_check(NodeHTTPSProxyServer, NodeWebSocketServer);
}
// ws h1.1 with insecure h1.1 proxy
async function test_h1_ws_with_insecure_h1_proxy() {
await spinup_and_check(NodeHTTPProxyServer, NodeWebSocketServer);
}
// ws h1.1 with h2 proxy
async function test_h1_ws_with_h2_proxy() {
await spinup_and_check(NodeHTTP2ProxyServer, NodeWebSocketServer);
}
// ws h2 with insecure h1.1 proxy
async function test_h2_ws_with_insecure_h1_proxy() {
await spinup_and_check(NodeHTTPProxyServer, NodeWebSocketHttp2Server);
}
// ws h2 with secure h1 proxy
async function test_h2_ws_with_secure_h1_proxy() {
await spinup_and_check(NodeHTTPSProxyServer, NodeWebSocketHttp2Server);
}
// ws h2 with secure h2 proxy
async function test_h2_ws_with_h2_proxy() {
await spinup_and_check(NodeHTTP2ProxyServer, NodeWebSocketHttp2Server);
}
add_task(test_h1_websocket_direct);
add_task(test_h2_websocket_direct);
add_task(test_h1_ws_with_secure_h1_proxy);
add_task(test_h1_ws_with_insecure_h1_proxy);
add_task(test_h1_ws_with_h2_proxy);
// any multi-client test with h2 websocket and any kind of proxy will fail/hang
add_task(test_h2_ws_with_insecure_h1_proxy);
add_task(test_h2_ws_with_secure_h1_proxy);
add_task(test_h2_ws_with_h2_proxy);