testing/web-platform/tests/xhr/abort-after-stop.htm
author Thomas Wisniewski <twisniewski@mozilla.com>
Mon, 11 Mar 2019 13:30:38 +0000
changeset 521382 9c46b805faebe42a7abc0a84fe5f35bacbb8970a
parent 491731 6cc4109ffbd1f0f060ba1689e3906eceaa27945d
permissions -rw-r--r--
Bug 1508377 - properly update XHR status when one is aborted because of an NS_BINDING_ABORTED confition such as window.stop(); r=baku properly update XHR status when one is aborted because of an NS_BINDING_ABORTED confition such as window.stop() Differential Revision: https://phabricator.services.mozilla.com/D22852

<!doctype html>
<html>
  <head>
    <title>XMLHttpRequest: abort event should fire when stop() method is used</title>
    <script src="/resources/testharness.js"></script>
    <script src="/resources/testharnessreport.js"></script>
    <link rel="help" href="https://xhr.spec.whatwg.org/#infrastructure-for-the-send()-method" data-tested-assertations="following::dt[3] following::dt[3]/following::dd[1]/p"/>
  </head>
  <body>
    <div id="log"></div>
    <script>
      var test = async_test();
      window.onload = test.step_func(function() {
        var client = new XMLHttpRequest();
        var abortFired = false;
        var sync = true;
        client.onabort = test.step_func(function (e) {
          assert_false(sync);
          assert_equals(e.type, 'abort');
          assert_equals(client.status, 0);
          abortFired = true;
        });
        client.open("GET", "resources/delay.py?ms=3000", true);
        client.send(null);
        test.step_timeout(() => {
          assert_equals(abortFired, true);
          test.done();
        }, 200);
        window.stop();
        sync = false;
      });
    </script>
  </body>
</html>