diff options
author | Matt A. Tobin <email@mattatobin.com> | 2018-02-11 07:03:16 -0500 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2018-02-11 07:03:16 -0500 |
commit | 203eb0f61a09372310a2a8fb57e169cb3f47800b (patch) | |
tree | 8490329d3dae4de3c7ffd127bce1f65fdc009abd /toolkit/mozapps/extensions/test/xpcshell/test_bug397778.js | |
parent | e45706ca3acbb6530419433212becc61d5953a2d (diff) | |
parent | 8f6d3dab81c7f8f97ef197e26ab9439b09735b8f (diff) | |
download | UXP-ed96a7148c31f5448b81800287c09ce7169223cc.tar UXP-ed96a7148c31f5448b81800287c09ce7169223cc.tar.gz UXP-ed96a7148c31f5448b81800287c09ce7169223cc.tar.lz UXP-ed96a7148c31f5448b81800287c09ce7169223cc.tar.xz UXP-ed96a7148c31f5448b81800287c09ce7169223cc.zip |
Merge branch 'ext-work'FF_Checkpoint_1
Diffstat (limited to 'toolkit/mozapps/extensions/test/xpcshell/test_bug397778.js')
-rw-r--r-- | toolkit/mozapps/extensions/test/xpcshell/test_bug397778.js | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/toolkit/mozapps/extensions/test/xpcshell/test_bug397778.js b/toolkit/mozapps/extensions/test/xpcshell/test_bug397778.js new file mode 100644 index 000000000..aa18a6946 --- /dev/null +++ b/toolkit/mozapps/extensions/test/xpcshell/test_bug397778.js @@ -0,0 +1,117 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ + +const PREF_MATCH_OS_LOCALE = "intl.locale.matchOS"; +const PREF_SELECTED_LOCALE = "general.useragent.locale"; + +const ADDON = "test_bug397778"; +const ID = "bug397778@tests.mozilla.org"; + +function run_test() +{ + // Setup for test + do_test_pending(); + createAppInfo("xpcshell@tests.mozilla.org", "XPCShell", "1"); + Services.prefs.setBoolPref(PREF_MATCH_OS_LOCALE, false); + Services.prefs.setCharPref(PREF_SELECTED_LOCALE, "fr-FR"); + + // Install test add-on + startupManager(); + installAllFiles([do_get_addon(ADDON)], function() { + restartManager(); + + run_test_1(); + }); +} + +function run_test_1() { + AddonManager.getAddonByID(ID, callback_soon(function(addon) { + do_check_neq(addon, null); + do_check_eq(addon.name, "fr Name"); + do_check_eq(addon.description, "fr Description"); + + // Disable item + addon.userDisabled = true; + restartManager(); + + AddonManager.getAddonByID(ID, function(newAddon) { + do_check_neq(newAddon, null); + do_check_eq(newAddon.name, "fr Name"); + + do_execute_soon(run_test_2); + }); + })); +} + +function run_test_2() { + // Change locale. The more specific de-DE is the best match + Services.prefs.setCharPref(PREF_SELECTED_LOCALE, "de"); + restartManager(); + + AddonManager.getAddonByID(ID, function(addon) { + do_check_neq(addon, null); + do_check_eq(addon.name, "de-DE Name"); + do_check_eq(addon.description, null); + + do_execute_soon(run_test_3); + }); +} + +function run_test_3() { + // Change locale. Locale case should have no effect + Services.prefs.setCharPref(PREF_SELECTED_LOCALE, "DE-de"); + restartManager(); + + AddonManager.getAddonByID(ID, function(addon) { + do_check_neq(addon, null); + do_check_eq(addon.name, "de-DE Name"); + do_check_eq(addon.description, null); + + do_execute_soon(run_test_4); + }); +} + +function run_test_4() { + // Change locale. es-ES should closely match + Services.prefs.setCharPref(PREF_SELECTED_LOCALE, "es-AR"); + restartManager(); + + AddonManager.getAddonByID(ID, function(addon) { + do_check_neq(addon, null); + do_check_eq(addon.name, "es-ES Name"); + do_check_eq(addon.description, "es-ES Description"); + + do_execute_soon(run_test_5); + }); +} + +function run_test_5() { + // Change locale. Either zh-CN or zh-TW could match + Services.prefs.setCharPref(PREF_SELECTED_LOCALE, "zh"); + restartManager(); + + AddonManager.getAddonByID(ID, function(addon) { + do_check_neq(addon, null); + if (addon.name != "zh-TW Name" && addon.name != "zh-CN Name") + do_throw("zh matched to " + addon.name); + + do_execute_soon(run_test_6); + }); +} + +function run_test_6() { + // Unknown locale should try to match against en-US as well. Of en,en-GB + // en should match as being less specific + Services.prefs.setCharPref(PREF_SELECTED_LOCALE, "nl-NL"); + restartManager(); + + AddonManager.getAddonByID(ID, function(addon) { + do_check_neq(addon, null); + do_check_eq(addon.name, "en Name"); + do_check_eq(addon.description, "en Description"); + + do_execute_soon(do_test_finished); + }); +} |