/* vim:set ts=2 sw=2 sts=2 et: */ /* Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ // Tests that the Web Console shows weak crypto warnings (SHA-1 Certificate, SSLv3, and RC4) "use strict"; const TEST_URI = "data:text/html;charset=utf8,Web Console weak crypto " + "warnings test"; const TEST_URI_PATH = "/browser/devtools/client/webconsole/test/" + "test-certificate-messages.html"; var gWebconsoleTests = [ {url: "https://sha1ee.example.com" + TEST_URI_PATH, name: "SHA1 warning displayed successfully", warning: ["SHA-1"], nowarning: ["SSL 3.0", "RC4"]}, {url: "https://rc4.example.com" + TEST_URI_PATH, name: "RC4 warning displayed successfully", pref: [["security.tls.insecure_fallback_hosts", "rc4.example.com"]], warning: ["RC4"], nowarning: ["SHA-1", "SSL 3.0"]}, {url: "https://rc4.example.com" + TEST_URI_PATH + "?", name: "Unrestricted RC4 fallback worked", pref: [["security.tls.unrestricted_rc4_fallback", true]], warning: ["RC4"], nowarning: ["SHA-1", "SSL 3.0"]}, {url: "https://sha256ee.example.com" + TEST_URI_PATH, name: "SSL warnings appropriately not present", warning: [], nowarning: ["SHA-1", "SSL 3.0", "RC4"]}, ]; const TRIGGER_MSG = "If you haven't seen ssl warnings yet, you won't"; var gHud = undefined, gContentBrowser; var gCurrentTest; function test() { registerCleanupFunction(function() { gHud = gContentBrowser = null; }); loadTab(TEST_URI).then(({browser}) => { gContentBrowser = browser; openConsole().then(runTestLoop); }); } function runTestLoop(theHud) { gCurrentTest = gWebconsoleTests.shift(); if (!gCurrentTest) { finishTest(); return; } if (!gHud) { gHud = theHud; } gHud.jsterm.clearOutput(); gContentBrowser.addEventListener("load", onLoad, true); if (gCurrentTest.pref) { SpecialPowers.pushPrefEnv({"set": gCurrentTest.pref}, function() { content.location = gCurrentTest.url; }); } else { content.location = gCurrentTest.url; } } function onLoad() { gContentBrowser.removeEventListener("load", onLoad, true); waitForSuccess({ name: gCurrentTest.name, validator: function() { if (gHud.outputNode.textContent.indexOf(TRIGGER_MSG) >= 0) { for (let warning of gCurrentTest.warning) { if (gHud.outputNode.textContent.indexOf(warning) < 0) { return false; } } for (let nowarning of gCurrentTest.nowarning) { if (gHud.outputNode.textContent.indexOf(nowarning) >= 0) { return false; } } return true; } } }).then(runTestLoop); }