diff options
Diffstat (limited to 'toolkit/components/captivedetect/test/unit/test_captive_portal_found.js')
-rw-r--r-- | toolkit/components/captivedetect/test/unit/test_captive_portal_found.js | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/toolkit/components/captivedetect/test/unit/test_captive_portal_found.js b/toolkit/components/captivedetect/test/unit/test_captive_portal_found.js new file mode 100644 index 000000000..7fb7ba89e --- /dev/null +++ b/toolkit/components/captivedetect/test/unit/test_captive_portal_found.js @@ -0,0 +1,67 @@ +/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */ +/* 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'; + +const kInterfaceName = 'wifi'; + +var server; +var step = 0; +var loginFinished = false; + +function xhr_handler(metadata, response) { + response.setStatusLine(metadata.httpVersion, 200, 'OK'); + response.setHeader('Cache-Control', 'no-cache', false); + response.setHeader('Content-Type', 'text/plain', false); + if (loginFinished) { + response.write('true'); + } else { + response.write('false'); + } +} + +function fakeUIResponse() { + Services.obs.addObserver(function observe(subject, topic, data) { + if (topic === 'captive-portal-login') { + let xhr = Cc['@mozilla.org/xmlextras/xmlhttprequest;1'] + .createInstance(Ci.nsIXMLHttpRequest); + xhr.open('GET', gServerURL + kCanonicalSitePath, true); + xhr.send(); + loginFinished = true; + do_check_eq(++step, 2); + } + }, 'captive-portal-login', false); + + Services.obs.addObserver(function observe(subject, topic, data) { + if (topic === 'captive-portal-login-success') { + do_check_eq(++step, 4); + gServer.stop(do_test_finished); + } + }, 'captive-portal-login-success', false); +} + +function test_portal_found() { + do_test_pending(); + + let callback = { + QueryInterface: XPCOMUtils.generateQI([Ci.nsICaptivePortalCallback]), + prepare: function prepare() { + do_check_eq(++step, 1); + gCaptivePortalDetector.finishPreparation(kInterfaceName); + }, + complete: function complete(success) { + // Since this is a synchronous callback, it must happen before + // 'captive-portal-login-success' is received. + // (Check captivedetect.js::executeCallback + do_check_eq(++step, 3); + do_check_true(success); + }, + }; + + gCaptivePortalDetector.checkCaptivePortal(kInterfaceName, callback); +} + +function run_test() { + run_captivedetect_test(xhr_handler, fakeUIResponse, test_portal_found); +} |