forked from mirrors/gecko-dev
		
	 1f830c96da
			
		
	
	
		1f830c96da
		
	
	
	
	
		
			
			# ignore-this-changeset Differential Revision: https://phabricator.services.mozilla.com/D36042 --HG-- extra : source : d3afcafdce650a6f36cebbc126ee93b17f13cf52
		
			
				
	
	
		
			214 lines
		
	
	
	
		
			5.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			214 lines
		
	
	
	
		
			5.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/. */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| requestLongerTimeout(2);
 | |
| 
 | |
| var bookmarksToolbar = document.getElementById("PersonalToolbar");
 | |
| var navbar = document.getElementById("nav-bar");
 | |
| var tabsToolbar = document.getElementById("TabsToolbar");
 | |
| 
 | |
| // Customization reset should restore visibility to default-visible toolbars.
 | |
| add_task(async function() {
 | |
|   is(navbar.collapsed, false, "Test should start with navbar visible");
 | |
|   setToolbarVisibility(navbar, false);
 | |
|   is(navbar.collapsed, true, "navbar should be hidden now");
 | |
| 
 | |
|   await resetCustomization();
 | |
| 
 | |
|   is(
 | |
|     navbar.collapsed,
 | |
|     false,
 | |
|     "Customization reset should restore visibility to the navbar"
 | |
|   );
 | |
| });
 | |
| 
 | |
| // Customization reset should restore collapsed-state to default-collapsed toolbars.
 | |
| add_task(async function() {
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be in its default state"
 | |
|   );
 | |
| 
 | |
|   is(
 | |
|     bookmarksToolbar.collapsed,
 | |
|     true,
 | |
|     "Test should start with bookmarks toolbar collapsed"
 | |
|   );
 | |
|   ok(bookmarksToolbar.collapsed, "bookmarksToolbar should be collapsed");
 | |
|   ok(!tabsToolbar.collapsed, "TabsToolbar should not be collapsed");
 | |
|   is(navbar.collapsed, false, "The nav-bar should be shown by default");
 | |
| 
 | |
|   setToolbarVisibility(bookmarksToolbar, true);
 | |
|   setToolbarVisibility(navbar, false);
 | |
|   ok(!bookmarksToolbar.collapsed, "bookmarksToolbar should be visible now");
 | |
|   ok(navbar.collapsed, "navbar should be collapsed");
 | |
|   is(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     false,
 | |
|     "Should no longer be in default state"
 | |
|   );
 | |
| 
 | |
|   await startCustomizing();
 | |
|   await gCustomizeMode.reset();
 | |
|   await endCustomizing();
 | |
| 
 | |
|   is(
 | |
|     bookmarksToolbar.collapsed,
 | |
|     true,
 | |
|     "Customization reset should restore collapsed-state to the bookmarks toolbar"
 | |
|   );
 | |
|   ok(!tabsToolbar.collapsed, "TabsToolbar should not be collapsed");
 | |
|   ok(
 | |
|     bookmarksToolbar.collapsed,
 | |
|     "The bookmarksToolbar should be collapsed after reset"
 | |
|   );
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be back to default state"
 | |
|   );
 | |
| });
 | |
| 
 | |
| // Check that the menubar will be collapsed by resetting, if the platform supports it.
 | |
| add_task(async function() {
 | |
|   let menubar = document.getElementById("toolbar-menubar");
 | |
|   const canMenubarCollapse = CustomizableUI.isToolbarDefaultCollapsed(
 | |
|     menubar.id
 | |
|   );
 | |
|   if (!canMenubarCollapse) {
 | |
|     return;
 | |
|   }
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be in its default state"
 | |
|   );
 | |
| 
 | |
|   is(
 | |
|     menubar.getBoundingClientRect().height,
 | |
|     0,
 | |
|     "menubar should be hidden by default"
 | |
|   );
 | |
|   setToolbarVisibility(menubar, true);
 | |
|   isnot(
 | |
|     menubar.getBoundingClientRect().height,
 | |
|     0,
 | |
|     "menubar should be visible now"
 | |
|   );
 | |
| 
 | |
|   await startCustomizing();
 | |
|   await gCustomizeMode.reset();
 | |
| 
 | |
|   is(
 | |
|     menubar.getAttribute("autohide"),
 | |
|     "true",
 | |
|     "The menubar should have autohide=true after reset in customization mode"
 | |
|   );
 | |
|   is(
 | |
|     menubar.getBoundingClientRect().height,
 | |
|     0,
 | |
|     "The menubar should have height=0 after reset in customization mode"
 | |
|   );
 | |
| 
 | |
|   await endCustomizing();
 | |
| 
 | |
|   is(
 | |
|     menubar.getAttribute("autohide"),
 | |
|     "true",
 | |
|     "The menubar should have autohide=true after reset"
 | |
|   );
 | |
|   is(
 | |
|     menubar.getBoundingClientRect().height,
 | |
|     0,
 | |
|     "The menubar should have height=0 after reset"
 | |
|   );
 | |
| });
 | |
| 
 | |
| // Customization reset should restore collapsed-state to default-collapsed toolbars.
 | |
| add_task(async function() {
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be in its default state"
 | |
|   );
 | |
|   ok(bookmarksToolbar.collapsed, "bookmarksToolbar should be collapsed");
 | |
|   ok(!tabsToolbar.collapsed, "TabsToolbar should not be collapsed");
 | |
| 
 | |
|   setToolbarVisibility(bookmarksToolbar, true);
 | |
|   ok(!bookmarksToolbar.collapsed, "bookmarksToolbar should be visible now");
 | |
|   is(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     false,
 | |
|     "Should no longer be in default state"
 | |
|   );
 | |
| 
 | |
|   await startCustomizing();
 | |
| 
 | |
|   ok(
 | |
|     !bookmarksToolbar.collapsed,
 | |
|     "The bookmarksToolbar should be visible before reset"
 | |
|   );
 | |
|   ok(!navbar.collapsed, "The navbar should be visible before reset");
 | |
|   ok(!tabsToolbar.collapsed, "TabsToolbar should not be collapsed");
 | |
| 
 | |
|   await gCustomizeMode.reset();
 | |
| 
 | |
|   ok(
 | |
|     bookmarksToolbar.collapsed,
 | |
|     "The bookmarksToolbar should be collapsed after reset"
 | |
|   );
 | |
|   ok(!tabsToolbar.collapsed, "TabsToolbar should not be collapsed");
 | |
|   ok(!navbar.collapsed, "The navbar should still be visible after reset");
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be back to default state"
 | |
|   );
 | |
|   await endCustomizing();
 | |
| });
 | |
| 
 | |
| // Check that the menubar will be collapsed by resetting, if the platform supports it.
 | |
| add_task(async function() {
 | |
|   let menubar = document.getElementById("toolbar-menubar");
 | |
|   const canMenubarCollapse = CustomizableUI.isToolbarDefaultCollapsed(
 | |
|     menubar.id
 | |
|   );
 | |
|   if (!canMenubarCollapse) {
 | |
|     return;
 | |
|   }
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be in its default state"
 | |
|   );
 | |
|   await startCustomizing();
 | |
|   let resetButton = document.getElementById("customization-reset-button");
 | |
|   is(
 | |
|     resetButton.disabled,
 | |
|     true,
 | |
|     "The reset button should be disabled when in default state"
 | |
|   );
 | |
| 
 | |
|   setToolbarVisibility(menubar, true);
 | |
|   is(
 | |
|     resetButton.disabled,
 | |
|     false,
 | |
|     "The reset button should be enabled when not in default state"
 | |
|   );
 | |
|   ok(
 | |
|     !CustomizableUI.inDefaultState,
 | |
|     "No longer in default state when the menubar is shown"
 | |
|   );
 | |
| 
 | |
|   await gCustomizeMode.reset();
 | |
| 
 | |
|   is(
 | |
|     resetButton.disabled,
 | |
|     true,
 | |
|     "The reset button should be disabled when in default state"
 | |
|   );
 | |
|   ok(
 | |
|     CustomizableUI.inDefaultState,
 | |
|     "Everything should be in its default state"
 | |
|   );
 | |
| 
 | |
|   await endCustomizing();
 | |
| });
 |