/* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ function test() { waitForExplicitFinish(); showTabView(onTabViewWindowLoaded); } function onTabViewWindowLoaded() { ok(TabView.isVisible(), "Tab View is visible"); let contentWindow = TabView.getContentWindow(); // establish initial state is(contentWindow.GroupItems.groupItems.length, 1, "we start with one group (the default)"); is(gBrowser.tabs.length, 1, "we start with one tab"); let originalTab = gBrowser.tabs[0]; // create a group let box = new contentWindow.Rect(20, 20, 180, 180); let groupItemOne = new contentWindow.GroupItem([], { bounds: box, title: "test1" }); is(contentWindow.GroupItems.groupItems.length, 2, "we now have two groups"); contentWindow.UI.setActive(groupItemOne); // create a tab let xulTab = gBrowser.loadOneTab("about:blank"); is(gBrowser.tabs.length, 2, "we now have two tabs"); is(groupItemOne._children.length, 1, "the new tab was added to the group"); // make sure the group has no app tabs is(appTabCount(groupItemOne), 0, "there are no app tab icons"); // pin the tab, make sure the TabItem goes away and the icon comes on whenAppTabIconAdded(groupItemOne, function () { is(groupItemOne._children.length, 0, "the app tab's TabItem was removed from the group"); is(appTabCount(groupItemOne), 1, "there's now one app tab icon"); // create a second group and make sure it gets the icon too box.offset(box.width + 20, 0); let groupItemTwo = new contentWindow.GroupItem([], { bounds: box, title: "test2" }); whenAppTabIconAdded(groupItemTwo, function() { is(contentWindow.GroupItems.groupItems.length, 3, "we now have three groups"); is(appTabCount(groupItemTwo), 1, "there's an app tab icon in the second group"); // When the tab was pinned, the last active group with an item got the focus. // Therefore, switching the focus back to group item one. contentWindow.UI.setActive(groupItemOne); // unpin the tab, make sure the icon goes away and the TabItem comes on gBrowser.unpinTab(xulTab); is(groupItemOne._children.length, 1, "the app tab's TabItem is back"); is(appTabCount(groupItemOne), 0, "the icon is gone from group one"); is(appTabCount(groupItemTwo), 0, "the icon is gone from group two"); whenAppTabIconAdded(groupItemOne, function() { // close the second group groupItemTwo.close(); // find app tab in group and hit it whenTabViewIsHidden(function() { ok(!TabView.isVisible(), "Tab View is hidden because we clicked on the app tab"); // delete the app tab and make sure its icon goes away gBrowser.removeTab(xulTab); is(appTabCount(groupItemOne), 0, "closing app tab removes its icon"); // clean up groupItemOne.close(); is(contentWindow.GroupItems.groupItems.length, 1, "we finish with one group"); is(gBrowser.tabs.length, 1, "we finish with one tab"); ok(!TabView.isVisible(), "we finish with Tab View not visible"); finish(); }); let appTabIcons = groupItemOne.container.getElementsByClassName("appTabIcon"); EventUtils.sendMouseEvent({ type: "click" }, appTabIcons[0], contentWindow); }); gBrowser.pinTab(xulTab); }); }); gBrowser.pinTab(xulTab); } function appTabCount(groupItem) { return groupItem.container.getElementsByClassName("appTabIcon").length; }