mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-11-12 22:28:59 +02:00
- `Array.map` becomes `Array.from` - Array copying via `Array.slice` becomes `Array.from`. - `Array.forEach` that did not rely on closures becomes `for`-`of` loops. - Anything else: `Array.X` becomes `Array.prototype.X`. Complex cases: dom/bindings/test/TestInterfaceJS.js and dom/bindings/test/test_exception_options_from_jsimplemented.html use `Array.indexOf` to generate an error with a specific error message. Switched to `Array.prototype.forEach` to generate the same error. js/src/jit-test/tests/basic/exception-column-number.js In this test `Array.indexOf()` is used to generate an error. Since the exact message doesn't matter, I switched to `Array.from()`. Intentionally not changed: editor/libeditor/tests/browserscope/lib/richtext/richtext/js/range.js Did not modify because this is 3rd-party code and the code uses feature detection as a fall back when Array generics are not used. testing/talos/talos/tests/dromaeo/lib/mootools.js Did not modify because mootools adds the `Array.slice` method to the `Array` object. Not changed because they check the implementation of Array generics: js/src/jit-test/tests/basic/arrayNatives.js js/src/jit-test/tests/basic/bug563243.js js/src/jit-test/tests/basic/bug618853.js js/src/jit-test/tests/basic/bug830967.js js/src/jit-test/tests/jaeger/recompile/bug656753.js js/src/jit-test/tests/self-hosting/alternate-static-and-instance-array-extras.js js/src/tests/non262/Array/generics.js js/src/tests/non262/Array/regress-415540.js js/src/tests/non262/extensions/regress-355497.js js/src/tests/non262/extensions/typedarray-set-neutering.js Depends on D27802 Differential Revision: https://phabricator.services.mozilla.com/D27803 --HG-- extra : moz-landing-system : lando
57 lines
2.7 KiB
JavaScript
57 lines
2.7 KiB
JavaScript
/* 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/. */
|
|
|
|
add_task(async function() {
|
|
is(gBrowser.tabs.length, 1, "one tab is open initially");
|
|
|
|
// Add several new tabs in sequence, interrupted by selecting a
|
|
// different tab, moving a tab around and closing a tab,
|
|
// returning a list of opened tabs for verifying the expected order.
|
|
// The new tab behaviour is documented in bug 465673
|
|
let tabs = [];
|
|
let ReferrerInfo = Components.Constructor("@mozilla.org/referrer-info;1",
|
|
"nsIReferrerInfo",
|
|
"init");
|
|
|
|
function addTab(aURL, aReferrer) {
|
|
let referrerInfo = new ReferrerInfo(
|
|
Ci.nsIHttpChannel.REFERRER_POLICY_UNSET, true, aReferrer);
|
|
let tab = BrowserTestUtils.addTab(gBrowser, aURL, { referrerInfo });
|
|
tabs.push(tab);
|
|
return BrowserTestUtils.browserLoaded(tab.linkedBrowser);
|
|
}
|
|
|
|
await addTab("http://mochi.test:8888/#0");
|
|
gBrowser.selectedTab = tabs[0];
|
|
await addTab("http://mochi.test:8888/#1");
|
|
await addTab("http://mochi.test:8888/#2", gBrowser.currentURI);
|
|
await addTab("http://mochi.test:8888/#3", gBrowser.currentURI);
|
|
gBrowser.selectedTab = tabs[tabs.length - 1];
|
|
gBrowser.selectedTab = tabs[0];
|
|
await addTab("http://mochi.test:8888/#4", gBrowser.currentURI);
|
|
gBrowser.selectedTab = tabs[3];
|
|
await addTab("http://mochi.test:8888/#5", gBrowser.currentURI);
|
|
gBrowser.removeTab(tabs.pop());
|
|
await addTab("about:blank", gBrowser.currentURI);
|
|
gBrowser.moveTabTo(gBrowser.selectedTab, 1);
|
|
await addTab("http://mochi.test:8888/#6", gBrowser.currentURI);
|
|
await addTab();
|
|
await addTab("http://mochi.test:8888/#7");
|
|
|
|
function testPosition(tabNum, expectedPosition, msg) {
|
|
is(Array.prototype.indexOf.call(gBrowser.tabs, tabs[tabNum]), expectedPosition, msg);
|
|
}
|
|
|
|
testPosition(0, 3, "tab without referrer was opened to the far right");
|
|
testPosition(1, 7, "tab without referrer was opened to the far right");
|
|
testPosition(2, 5, "tab with referrer opened immediately to the right");
|
|
testPosition(3, 1, "next tab with referrer opened further to the right");
|
|
testPosition(4, 4, "tab selection changed, tab opens immediately to the right");
|
|
testPosition(5, 6, "blank tab with referrer opens to the right of 3rd original tab where removed tab was");
|
|
testPosition(6, 2, "tab has moved, new tab opens immediately to the right");
|
|
testPosition(7, 8, "blank tab without referrer opens at the end");
|
|
testPosition(8, 9, "tab without referrer opens at the end");
|
|
|
|
tabs.forEach(gBrowser.removeTab, gBrowser);
|
|
});
|