summaryrefslogtreecommitdiffstats
path: root/toolkit/components/captivedetect/test/unit/test_abort_pending_request.js
diff options
context:
space:
mode:
Diffstat (limited to 'toolkit/components/captivedetect/test/unit/test_abort_pending_request.js')
-rw-r--r--toolkit/components/captivedetect/test/unit/test_abort_pending_request.js71
1 files changed, 71 insertions, 0 deletions
diff --git a/toolkit/components/captivedetect/test/unit/test_abort_pending_request.js b/toolkit/components/captivedetect/test/unit/test_abort_pending_request.js
new file mode 100644
index 000000000..ce36f1e79
--- /dev/null
+++ b/toolkit/components/captivedetect/test/unit/test_abort_pending_request.js
@@ -0,0 +1,71 @@
+/* -*- 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';
+const kOtherInterfaceName = 'ril';
+
+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);
+}
+
+function test_abort() {
+ 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) {
+ do_check_eq(++step, 3);
+ do_check_true(success);
+ gServer.stop(do_test_finished);
+ },
+ };
+
+ let otherCallback = {
+ QueryInterface: XPCOMUtils.generateQI([Ci.nsICaptivePortalCallback]),
+ prepare: function prepare() {
+ do_throw('should not execute |prepare| callback for ' + kOtherInterfaceName);
+ },
+ complete: function complete(success) {
+ do_throw('should not execute |complete| callback for ' + kInterfaceName);
+ }
+ };
+
+ gCaptivePortalDetector.checkCaptivePortal(kInterfaceName, callback);
+ gCaptivePortalDetector.checkCaptivePortal(kOtherInterfaceName, otherCallback);
+ gCaptivePortalDetector.abort(kOtherInterfaceName);
+}
+
+function run_test() {
+ run_captivedetect_test(xhr_handler, fakeUIResponse, test_abort);
+}