michael@0: /* Any copyright is dedicated to the Public Domain. michael@0: * http://creativecommons.org/publicdomain/zero/1.0/ */ michael@0: michael@0: function test() { michael@0: const Cu = Components.utils; michael@0: let {ToolSidebar} = devtools.require("devtools/framework/sidebar"); michael@0: michael@0: const toolURL = "data:text/xml;charset=utf8," + michael@0: "" + michael@0: "" + michael@0: "foo" + michael@0: "" + michael@0: "" + michael@0: ""; michael@0: michael@0: const tab1URL = "data:text/html;charset=utf8,1

1

"; michael@0: const tab2URL = "data:text/html;charset=utf8,2

2

"; michael@0: const tab3URL = "data:text/html;charset=utf8,3

3

"; michael@0: michael@0: let panelDoc; michael@0: let tab1Selected = false; michael@0: let registeredTabs = {}; michael@0: let readyTabs = {}; michael@0: michael@0: let toolDefinition = { michael@0: id: "fakeTool4242", michael@0: visibilityswitch: "devtools.fakeTool4242.enabled", michael@0: url: toolURL, michael@0: label: "FAKE TOOL!!!", michael@0: isTargetSupported: function() true, michael@0: build: function(iframeWindow, toolbox) { michael@0: let deferred = promise.defer(); michael@0: executeSoon(function() { michael@0: deferred.resolve({ michael@0: target: toolbox.target, michael@0: toolbox: toolbox, michael@0: isReady: true, michael@0: destroy: function(){}, michael@0: panelDoc: iframeWindow.document, michael@0: }); michael@0: }.bind(this)); michael@0: return deferred.promise; michael@0: }, michael@0: }; michael@0: michael@0: gDevTools.registerTool(toolDefinition); michael@0: michael@0: addTab("about:blank", function(aBrowser, aTab) { michael@0: let target = TargetFactory.forTab(gBrowser.selectedTab); michael@0: gDevTools.showToolbox(target, toolDefinition.id).then(function(toolbox) { michael@0: let panel = toolbox.getPanel(toolDefinition.id); michael@0: ok(true, "Tool open"); michael@0: michael@0: let tabbox = panel.panelDoc.getElementById("sidebar"); michael@0: panel.sidebar = new ToolSidebar(tabbox, panel, "testbug865688", true); michael@0: michael@0: panel.sidebar.on("new-tab-registered", function(event, id) { michael@0: registeredTabs[id] = true; michael@0: }); michael@0: michael@0: panel.sidebar.once("tab1-ready", function(event) { michael@0: info(event); michael@0: readyTabs.tab1 = true; michael@0: allTabsReady(panel); michael@0: }); michael@0: michael@0: panel.sidebar.once("tab2-ready", function(event) { michael@0: info(event); michael@0: readyTabs.tab2 = true; michael@0: allTabsReady(panel); michael@0: }); michael@0: michael@0: panel.sidebar.once("tab3-ready", function(event) { michael@0: info(event); michael@0: readyTabs.tab3 = true; michael@0: allTabsReady(panel); michael@0: }); michael@0: michael@0: panel.sidebar.once("tab1-selected", function(event) { michael@0: info(event); michael@0: tab1Selected = true; michael@0: allTabsReady(panel); michael@0: }); michael@0: michael@0: panel.sidebar.addTab("tab1", tab1URL, true); michael@0: panel.sidebar.addTab("tab2", tab2URL); michael@0: panel.sidebar.addTab("tab3", tab3URL); michael@0: michael@0: panel.sidebar.show(); michael@0: }).then(null, console.error); michael@0: }); michael@0: michael@0: function allTabsReady(panel) { michael@0: if (!tab1Selected || !readyTabs.tab1 || !readyTabs.tab2 || !readyTabs.tab3) { michael@0: return; michael@0: } michael@0: michael@0: ok(registeredTabs.tab1, "tab1 registered"); michael@0: ok(registeredTabs.tab2, "tab2 registered"); michael@0: ok(registeredTabs.tab3, "tab3 registered"); michael@0: ok(readyTabs.tab1, "tab1 ready"); michael@0: ok(readyTabs.tab2, "tab2 ready"); michael@0: ok(readyTabs.tab3, "tab3 ready"); michael@0: michael@0: let tabs = panel.sidebar._tabbox.querySelectorAll("tab"); michael@0: let panels = panel.sidebar._tabbox.querySelectorAll("tabpanel"); michael@0: let label = 1; michael@0: for (let tab of tabs) { michael@0: is(tab.getAttribute("label"), label++, "Tab has the right title"); michael@0: } michael@0: is(label, 4, "Found the right amount of tabs."); michael@0: is(panel.sidebar._tabbox.selectedPanel, panels[0], "First tab is selected"); michael@0: ok(panel.sidebar.getCurrentTabID(), "tab1", "getCurrentTabID() is correct"); michael@0: michael@0: panel.sidebar.once("tab1-unselected", function() { michael@0: ok(true, "received 'unselected' event"); michael@0: panel.sidebar.once("tab2-selected", function() { michael@0: ok(true, "received 'selected' event"); michael@0: panel.sidebar.hide(); michael@0: is(panel.sidebar._tabbox.getAttribute("hidden"), "true", "Sidebar hidden"); michael@0: is(panel.sidebar.getWindowForTab("tab1").location.href, tab1URL, "Window is accessible"); michael@0: testWidth(panel); michael@0: }); michael@0: }); michael@0: michael@0: panel.sidebar.select("tab2"); michael@0: } michael@0: michael@0: function testWidth(panel) { michael@0: let tabbox = panel.panelDoc.getElementById("sidebar"); michael@0: tabbox.width = 420; michael@0: panel.sidebar.destroy().then(function() { michael@0: tabbox.width = 0; michael@0: panel.sidebar = new ToolSidebar(tabbox, panel, "testbug865688", true); michael@0: panel.sidebar.show(); michael@0: is(panel.panelDoc.getElementById("sidebar").width, 420, "Width restored") michael@0: finishUp(panel); michael@0: }); michael@0: } michael@0: michael@0: function finishUp(panel) { michael@0: panel.sidebar.destroy(); michael@0: gDevTools.unregisterTool(toolDefinition.id); michael@0: michael@0: executeSoon(function() { michael@0: gBrowser.removeCurrentTab(); michael@0: finish(); michael@0: }); michael@0: } michael@0: }