fune/browser/base/content/test/general/browser_selectTabAtIndex.js
Chris Peterson b52f88014f Bug 1276565 - Clamp out-of-range tab selection shortcuts and indexes instead of ignoring them. r=Gijs r=dao
CMD + a number key is a keyboard shortcut to select that tab number. (CMD+9 will always select the right-most tab, regardless of the tab count.) Currently, if the number is greater than the tab count, then the keyboard shortcut is ignored. With this patch, the right-most tab will be selected instead. For example, if there are five tabs and the user accidentally enters CMD+6 instead of CMD+5, selecting tab #5 is probably what they wanted instead of ignoring the keyboard shortcut.

Also expand the tab selection tests to cover more edge cases.
2016-06-02 22:50:01 -07:00

81 lines
1.9 KiB
JavaScript

"use strict";
function test() {
const isLinux = navigator.platform.indexOf("Linux") == 0;
function assertTab(expectedTab) {
is(gBrowser.tabContainer.selectedIndex, expectedTab,
`tab index ${expectedTab} should be selected`);
}
function sendAccelKey(key) {
// Make sure the keystroke goes to chrome.
document.activeElement.blur();
EventUtils.synthesizeKey(key.toString(), { altKey: isLinux, accelKey: !isLinux });
}
function createTabs(count) {
for (let n = 0; n < count; n++)
gBrowser.addTab();
}
function testKey(key, expectedTab) {
sendAccelKey(key);
assertTab(expectedTab);
}
function testIndex(index, expectedTab) {
gBrowser.selectTabAtIndex(index);
assertTab(expectedTab);
}
// Create fewer tabs than our 9 number keys.
is(gBrowser.tabs.length, 1, "should have 1 tab");
createTabs(4);
is(gBrowser.tabs.length, 5, "should have 5 tabs");
// Test keyboard shortcuts. Order tests so that no two test cases have the
// same expected tab in a row. This ensures that tab selection actually
// changed the selected tab.
testKey(8, 4);
testKey(1, 0);
testKey(2, 1);
testKey(4, 3);
testKey(9, 4);
// Test index selection.
testIndex(0, 0);
testIndex(4, 4);
testIndex(-5, 0);
testIndex(5, 4);
testIndex(-4, 1);
testIndex(1, 1);
testIndex(-1, 4);
testIndex(9, 4);
// Create more tabs than our 9 number keys.
createTabs(10);
is(gBrowser.tabs.length, 15, "should have 15 tabs");
// Test keyboard shortcuts.
testKey(2, 1);
testKey(1, 0);
testKey(4, 3);
testKey(8, 7);
testKey(9, 14);
// Test index selection.
testIndex(-15, 0);
testIndex(14, 14);
testIndex(-14, 1);
testIndex(15, 14);
testIndex(-1, 14);
testIndex(0, 0);
testIndex(1, 1);
testIndex(9, 9);
// Clean up tabs.
for (let n = 15; n > 1; n--)
gBrowser.removeTab(gBrowser.selectedTab, {skipPermitUnload: true});
is(gBrowser.tabs.length, 1, "should have 1 tab");
}