forked from mirrors/gecko-dev
MozReview-Commit-ID: Asigfu41hTv --HG-- extra : rebase_source : c0d01ebe5e5437c876ff97c4aa55f3091875a9dd
70 lines
2.2 KiB
JavaScript
70 lines
2.2 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
"use strict";
|
|
|
|
var {classes: Cc, interfaces: Ci, utils: Cu, results: Cr} = Components;
|
|
|
|
XPCOMUtils.defineLazyModuleGetter(this, "fxAccounts",
|
|
"resource://gre/modules/FxAccounts.jsm");
|
|
|
|
var gTestTab;
|
|
var gContentAPI;
|
|
var gContentWindow;
|
|
|
|
function test() {
|
|
UITourTest();
|
|
}
|
|
|
|
registerCleanupFunction(async function() {
|
|
await signOut();
|
|
gSync.updateAllUI(UIState.get());
|
|
});
|
|
|
|
var tests = [
|
|
taskify(async function test_highlight_accountStatus_loggedOut() {
|
|
let userData = await fxAccounts.getSignedInUser();
|
|
is(userData, null, "Not logged in initially");
|
|
await showMenuPromise("appMenu");
|
|
await showHighlightPromise("accountStatus");
|
|
let highlight = document.getElementById("UITourHighlightContainer");
|
|
is(highlight.getAttribute("targetName"), "accountStatus", "Correct highlight target");
|
|
}),
|
|
|
|
taskify(async function test_highlight_accountStatus_loggedIn() {
|
|
await setSignedInUser();
|
|
let userData = await fxAccounts.getSignedInUser();
|
|
isnot(userData, null, "Logged in now");
|
|
gSync.updateAllUI(UIState.get());
|
|
await showMenuPromise("appMenu");
|
|
await showHighlightPromise("accountStatus");
|
|
let highlight = document.getElementById("UITourHighlightContainer");
|
|
let photon = Services.prefs.getBoolPref("browser.photon.structure.enabled");
|
|
let expectedTarget = photon ? "appMenu-fxa-avatar" : "PanelUI-fxa-avatar";
|
|
is(highlight.popupBoxObject.anchorNode.id, expectedTarget, "Anchored on avatar");
|
|
is(highlight.getAttribute("targetName"), "accountStatus", "Correct highlight target");
|
|
}),
|
|
];
|
|
|
|
// Helpers copied from browser_aboutAccounts.js
|
|
// watch out - these will fire observers which if you aren't careful, may
|
|
// interfere with the tests.
|
|
function setSignedInUser(data) {
|
|
if (!data) {
|
|
data = {
|
|
email: "foo@example.com",
|
|
uid: "1234@lcip.org",
|
|
assertion: "foobar",
|
|
sessionToken: "dead",
|
|
kA: "beef",
|
|
kB: "cafe",
|
|
verified: true
|
|
};
|
|
}
|
|
return fxAccounts.setSignedInUser(data);
|
|
}
|
|
|
|
function signOut() {
|
|
// we always want a "localOnly" signout here...
|
|
return fxAccounts.signOut(true);
|
|
}
|