diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /dom/tests/unit/test_geolocation_position_unavailable.js | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/tests/unit/test_geolocation_position_unavailable.js')
-rw-r--r-- | dom/tests/unit/test_geolocation_position_unavailable.js | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/dom/tests/unit/test_geolocation_position_unavailable.js b/dom/tests/unit/test_geolocation_position_unavailable.js new file mode 100644 index 0000000000..7e1584b661 --- /dev/null +++ b/dom/tests/unit/test_geolocation_position_unavailable.js @@ -0,0 +1,30 @@ +const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm"); + +function successCallback() { + Assert.ok(false); + do_test_finished(); +} + +function errorCallback(err) { + // GeolocationPositionError has no interface object, so we can't get constants off that. + Assert.equal(err.POSITION_UNAVAILABLE, err.code); + Assert.equal(2, err.code); + do_test_finished(); +} + +function run_test() { + do_test_pending(); + + if (Services.appinfo.processType == Ci.nsIXULRuntime.PROCESS_TYPE_DEFAULT) { + // XPCShell does not get a profile by default. The geolocation service + // depends on the settings service which uses IndexedDB and IndexedDB + // needs a place where it can store databases. + do_get_profile(); + + Services.prefs.setBoolPref("geo.provider.network.scan", false); + Services.prefs.setCharPref("geo.provider.network.url", "UrlNotUsedHere:"); + } + + var geolocation = Cc["@mozilla.org/geolocation;1"].getService(Ci.nsISupports); + geolocation.getCurrentPosition(successCallback, errorCallback); +} |