summaryrefslogtreecommitdiffstats
path: root/services/sync/tests/unit/test_fxa_service_cluster.js
blob: b4f83a7fe66041683ba4e90b5691ec84d93fd438 (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
57
58
59
60
61
62
63
64
65
66
67
68
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

Cu.import("resource://services-sync/service.js");
Cu.import("resource://services-sync/util.js");
Cu.import("resource://testing-common/services/sync/fxa_utils.js");
Cu.import("resource://testing-common/services/sync/utils.js");

add_task(function* test_findCluster() {
  _("Test FxA _findCluster()");

  _("_findCluster() throws on 500 errors.");
  initializeIdentityWithTokenServerResponse({
    status: 500,
    headers: [],
    body: "",
  });

  yield Service.identity.initializeWithCurrentIdentity();
  yield Assert.rejects(Service.identity.whenReadyToAuthenticate.promise,
                       "should reject due to 500");

  Assert.throws(function() {
    Service._clusterManager._findCluster();
  });

  _("_findCluster() returns null on authentication errors.");
  initializeIdentityWithTokenServerResponse({
    status: 401,
    headers: {"content-type": "application/json"},
    body: "{}",
  });

  yield Service.identity.initializeWithCurrentIdentity();
  yield Assert.rejects(Service.identity.whenReadyToAuthenticate.promise,
                       "should reject due to 401");

  cluster = Service._clusterManager._findCluster();
  Assert.strictEqual(cluster, null);

  _("_findCluster() works with correct tokenserver response.");
  let endpoint = "http://example.com/something";
  initializeIdentityWithTokenServerResponse({
    status: 200,
    headers: {"content-type": "application/json"},
    body:
      JSON.stringify({
        api_endpoint: endpoint,
        duration: 300,
        id: "id",
        key: "key",
        uid: "uid",
      })
  });

  yield Service.identity.initializeWithCurrentIdentity();
  yield Service.identity.whenReadyToAuthenticate.promise;
  cluster = Service._clusterManager._findCluster();
  // The cluster manager ensures a trailing "/"
  Assert.strictEqual(cluster, endpoint + "/");

  Svc.Prefs.resetBranch("");
});

function run_test() {
  initTestLogging();
  run_next_test();
}