summaryrefslogtreecommitdiff
path: root/toolkit/components/passwordmgr/test/mochitest/test_bug_776171.html
blob: 4ad08bee26ec2137d21a65d75281145e92d303a2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=776171
-->
<head>
  <meta charset="utf-8">
  <title>Test for Bug 776171 related to HTTP auth</title>
  <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
  <script type="text/javascript" src="pwmgr_common.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body onload="startTest()">
<script class="testbody" type="text/javascript">

/**
 * This test checks we correctly ignore authentication entry
 * for a subpath and use creds from the URL when provided when XHR
 * is used with filled user name and password.
 *
 * 1. connect auth2/authenticate.sjs that expects user1:pass1 password
 * 2. connect a dummy URL at the same path
 * 3. connect authenticate.sjs that again expects user1:pass1 password
 *    in this case, however, we have an entry without an identity
 *    for this path (that is a parent for auth2 path in the first step)
 */

SimpleTest.waitForExplicitFinish();

function doxhr(URL, user, pass, next) {
  var xhr = new XMLHttpRequest();
  if (user && pass)
    xhr.open("POST", URL, true, user, pass);
  else
    xhr.open("POST", URL, true);
  xhr.onload = function() {
    is(xhr.status, 200, "Got status 200");
    next();
  };
  xhr.onerror = function() {
    ok(false, "request passed");
    finishTest();
  };
  xhr.send();
}

function startTest() {
  doxhr("auth2/authenticate.sjs?user=user1&pass=pass1&realm=realm1", "user1", "pass1", function() {
    doxhr("auth2", null, null, function() {
      doxhr("authenticate.sjs?user=user1&pass=pass1&realm=realm1", "user1", "pass1", SimpleTest.finish);
    });
  });
}
</script>
</body>
</html>