mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
38347b08b2
The Weave.Service.account property holds whatever the user entered for email address/username. If it only contains characters valid for usernames, it is assumed to be a username. Otherwise it's SHA1 hashed and base32 encoded. The special tab mangling (to avoid broken Basic Auth headers) is now obsolete. --HG-- rename : services/sync/tests/unit/test_service_checkUsername.js => services/sync/tests/unit/test_service_checkAccount.js
242 lines
9.1 KiB
JavaScript
242 lines
9.1 KiB
JavaScript
Cu.import("resource://services-sync/base_records/keys.js");
|
|
Cu.import("resource://services-sync/constants.js");
|
|
Cu.import("resource://services-sync/identity.js");
|
|
Cu.import("resource://services-sync/service.js");
|
|
Cu.import("resource://services-sync/status.js");
|
|
Cu.import("resource://services-sync/util.js");
|
|
|
|
function test_identities() {
|
|
_("Account related Service properties correspond to preference settings and update other object properties upon being set.");
|
|
|
|
try {
|
|
_("Verify initial state");
|
|
do_check_eq(Svc.Prefs.get("account"), undefined);
|
|
do_check_eq(Svc.Prefs.get("username"), undefined);
|
|
do_check_eq(ID.get("WeaveID").username, "");
|
|
do_check_eq(ID.get("WeaveCryptoID").username, "");
|
|
|
|
_("The 'username' attribute is normalized to lower case, updates preferences and identities.");
|
|
Service.username = "TarZan";
|
|
do_check_eq(Service.username, "tarzan");
|
|
do_check_eq(Svc.Prefs.get("username"), "tarzan");
|
|
do_check_eq(ID.get("WeaveID").username, "tarzan");
|
|
do_check_eq(ID.get("WeaveCryptoID").username, "tarzan");
|
|
|
|
_("If not set, the 'account attribute' falls back to the username for backwards compatibility.");
|
|
do_check_eq(Service.account, "tarzan");
|
|
|
|
_("Setting 'username' to a non-truthy value resets the pref.");
|
|
Service.username = null;
|
|
do_check_eq(Service.username, "");
|
|
do_check_eq(Service.account, "");
|
|
const default_marker = {};
|
|
do_check_eq(Svc.Prefs.get("username", default_marker), default_marker);
|
|
do_check_eq(ID.get("WeaveID").username, null);
|
|
do_check_eq(ID.get("WeaveCryptoID").username, null);
|
|
|
|
_("The 'account' attribute will set the 'username' if it doesn't contain characters that aren't allowed in the username.");
|
|
Service.account = "johndoe";
|
|
do_check_eq(Service.account, "johndoe");
|
|
do_check_eq(Service.username, "johndoe");
|
|
do_check_eq(Svc.Prefs.get("username"), "johndoe");
|
|
do_check_eq(ID.get("WeaveID").username, "johndoe");
|
|
do_check_eq(ID.get("WeaveCryptoID").username, "johndoe");
|
|
|
|
_("If 'account' contains disallowed characters such as @, 'username' will the base32 encoded SHA1 hash of 'account'");
|
|
Service.account = "John@Doe.com";
|
|
do_check_eq(Service.account, "john@doe.com");
|
|
do_check_eq(Service.username, "7wohs32cngzuqt466q3ge7indszva4of");
|
|
|
|
_("Setting 'account' to a non-truthy value resets the pref.");
|
|
Service.account = null;
|
|
do_check_eq(Service.account, "");
|
|
do_check_eq(Svc.Prefs.get("account", default_marker), default_marker);
|
|
do_check_eq(Service.username, "");
|
|
do_check_eq(Svc.Prefs.get("username", default_marker), default_marker);
|
|
|
|
} finally {
|
|
Svc.Prefs.resetBranch("");
|
|
}
|
|
}
|
|
|
|
function test_urls() {
|
|
_("URL related Service properties corresopnd to preference settings.");
|
|
try {
|
|
do_check_eq(PubKeys.defaultKeyUri, undefined);
|
|
do_check_eq(PrivKeys.defaultKeyUri, undefined);
|
|
do_check_true(!!Service.serverURL); // actual value may change
|
|
do_check_eq(Service.clusterURL, "");
|
|
do_check_eq(Service.userBaseURL, undefined);
|
|
do_check_eq(Service.infoURL, undefined);
|
|
do_check_eq(Service.storageURL, undefined);
|
|
do_check_eq(Service.metaURL, undefined);
|
|
|
|
_("The 'clusterURL' attribute updates preferences and cached URLs.");
|
|
Service.username = "johndoe";
|
|
|
|
// Since we don't have a cluster URL yet, these will still not be defined.
|
|
do_check_eq(Service.infoURL, undefined);
|
|
do_check_eq(Service.userBaseURL, undefined);
|
|
do_check_eq(Service.storageURL, undefined);
|
|
do_check_eq(Service.metaURL, undefined);
|
|
do_check_eq(PubKeys.defaultKeyUri, undefined);
|
|
do_check_eq(PrivKeys.defaultKeyUri, undefined);
|
|
|
|
Service.serverURL = "http://weave.server/";
|
|
Service.clusterURL = "http://weave.cluster/";
|
|
do_check_eq(Svc.Prefs.get("clusterURL"), "http://weave.cluster/");
|
|
|
|
do_check_eq(Service.userBaseURL, "http://weave.cluster/1.0/johndoe/");
|
|
do_check_eq(Service.infoURL,
|
|
"http://weave.cluster/1.0/johndoe/info/collections");
|
|
do_check_eq(Service.storageURL,
|
|
"http://weave.cluster/1.0/johndoe/storage/");
|
|
do_check_eq(Service.metaURL,
|
|
"http://weave.cluster/1.0/johndoe/storage/meta/global");
|
|
do_check_eq(PubKeys.defaultKeyUri,
|
|
"http://weave.cluster/1.0/johndoe/storage/keys/pubkey");
|
|
do_check_eq(PrivKeys.defaultKeyUri,
|
|
"http://weave.cluster/1.0/johndoe/storage/keys/privkey");
|
|
|
|
_("The 'miscURL' and 'userURL' attributes can be relative to 'serverURL' or absolute.");
|
|
Svc.Prefs.set("miscURL", "relative/misc/");
|
|
Svc.Prefs.set("userURL", "relative/user/");
|
|
do_check_eq(Service.miscAPI,
|
|
"http://weave.server/relative/misc/1.0/");
|
|
do_check_eq(Service.userAPI,
|
|
"http://weave.server/relative/user/1.0/");
|
|
|
|
Svc.Prefs.set("miscURL", "http://weave.misc.services/");
|
|
Svc.Prefs.set("userURL", "http://weave.user.services/");
|
|
do_check_eq(Service.miscAPI, "http://weave.misc.services/1.0/");
|
|
do_check_eq(Service.userAPI, "http://weave.user.services/1.0/");
|
|
|
|
do_check_eq(Service.pwResetURL,
|
|
"http://weave.server/weave-password-reset");
|
|
|
|
_("Empty/false value for 'username' resets preference.");
|
|
Service.username = "";
|
|
do_check_eq(Svc.Prefs.get("username"), undefined);
|
|
do_check_eq(ID.get("WeaveID").username, "");
|
|
do_check_eq(ID.get("WeaveCryptoID").username, "");
|
|
|
|
_("The 'serverURL' attributes updates/resets preferences.");
|
|
// Identical value doesn't do anything
|
|
Service.serverURL = Service.serverURL;
|
|
do_check_eq(Svc.Prefs.get("clusterURL"), "http://weave.cluster/");
|
|
|
|
Service.serverURL = "http://different.auth.node/";
|
|
do_check_eq(Svc.Prefs.get("serverURL"), "http://different.auth.node/");
|
|
do_check_eq(Svc.Prefs.get("clusterURL"), undefined);
|
|
|
|
} finally {
|
|
Svc.Prefs.resetBranch("");
|
|
}
|
|
}
|
|
|
|
|
|
function test_syncID() {
|
|
_("Service.syncID is auto-generated, corresponds to preference.");
|
|
new FakeGUIDService();
|
|
|
|
try {
|
|
// Ensure pristine environment
|
|
do_check_eq(Svc.Prefs.get("client.syncID"), undefined);
|
|
|
|
// Performing the first get on the attribute will generate a new GUID.
|
|
do_check_eq(Service.syncID, "fake-guid-0");
|
|
do_check_eq(Svc.Prefs.get("client.syncID"), "fake-guid-0");
|
|
|
|
Svc.Prefs.set("client.syncID", Utils.makeGUID());
|
|
do_check_eq(Svc.Prefs.get("client.syncID"), "fake-guid-1");
|
|
do_check_eq(Service.syncID, "fake-guid-1");
|
|
} finally {
|
|
Svc.Prefs.resetBranch("");
|
|
new FakeGUIDService();
|
|
}
|
|
}
|
|
|
|
|
|
function test_prefAttributes() {
|
|
_("Test various attributes corresponding to preferences.");
|
|
|
|
const TIMESTAMP1 = 1275493471649;
|
|
const TIMESTAMP2 = 1275493741122;
|
|
const INTERVAL = 42 * 60 * 1000; // 42 minutes
|
|
const THRESHOLD = 3142;
|
|
const SCORE = 2718;
|
|
const NUMCLIENTS = 42;
|
|
|
|
try {
|
|
_("The 'nextSync' and 'nextHeartbeat' attributes store a millisecond timestamp to the nearest second.");
|
|
do_check_eq(Service.nextSync, 0);
|
|
do_check_eq(Service.nextHeartbeat, 0);
|
|
Service.nextSync = TIMESTAMP1;
|
|
Service.nextHeartbeat = TIMESTAMP2;
|
|
do_check_eq(Service.nextSync, Math.floor(TIMESTAMP1/1000)*1000);
|
|
do_check_eq(Service.nextHeartbeat, Math.floor(TIMESTAMP2/1000)*1000);
|
|
|
|
_("'syncInterval' has a non-zero default value.");
|
|
do_check_eq(Svc.Prefs.get('syncInterval'), undefined);
|
|
do_check_true(Service.syncInterval > 0);
|
|
|
|
_("'syncInterval' corresponds to a preference setting.");
|
|
Service.syncInterval = INTERVAL;
|
|
do_check_eq(Service.syncInterval, INTERVAL);
|
|
do_check_eq(Svc.Prefs.get('syncInterval'), INTERVAL);
|
|
|
|
_("'syncInterval' ignored preference setting after partial sync..");
|
|
Status.partial = true;
|
|
do_check_eq(Service.syncInterval, PARTIAL_DATA_SYNC);
|
|
|
|
_("'syncThreshold' corresponds to preference, has non-zero default.");
|
|
do_check_eq(Svc.Prefs.get('syncThreshold'), undefined);
|
|
do_check_true(Service.syncThreshold > 0);
|
|
Service.syncThreshold = THRESHOLD;
|
|
do_check_eq(Service.syncThreshold, THRESHOLD);
|
|
do_check_eq(Svc.Prefs.get('syncThreshold'), THRESHOLD);
|
|
|
|
_("'globalScore' corresponds to preference, defaults to zero.");
|
|
do_check_eq(Svc.Prefs.get('globalScore'), undefined);
|
|
do_check_eq(Service.globalScore, 0);
|
|
Service.globalScore = SCORE;
|
|
do_check_eq(Service.globalScore, SCORE);
|
|
do_check_eq(Svc.Prefs.get('globalScore'), SCORE);
|
|
|
|
_("'numClients' corresponds to preference, defaults to zero.");
|
|
do_check_eq(Svc.Prefs.get('numClients'), undefined);
|
|
do_check_eq(Service.numClients, 0);
|
|
Service.numClients = NUMCLIENTS;
|
|
do_check_eq(Service.numClients, NUMCLIENTS);
|
|
do_check_eq(Svc.Prefs.get('numClients'), NUMCLIENTS);
|
|
|
|
} finally {
|
|
Svc.Prefs.resetBranch("");
|
|
}
|
|
}
|
|
|
|
|
|
function test_locked() {
|
|
_("The 'locked' attribute can be toggled with lock() and unlock()");
|
|
|
|
// Defaults to false
|
|
do_check_eq(Service.locked, false);
|
|
|
|
do_check_eq(Service.lock(), true);
|
|
do_check_eq(Service.locked, true);
|
|
|
|
// Locking again will return false
|
|
do_check_eq(Service.lock(), false);
|
|
|
|
Service.unlock();
|
|
do_check_eq(Service.locked, false);
|
|
}
|
|
|
|
function run_test() {
|
|
test_identities();
|
|
test_urls();
|
|
test_syncID();
|
|
test_prefAttributes();
|
|
test_locked();
|
|
}
|