Chromium Code Reviews| Index: chrome/test/data/webui/md_bookmarks/md_bookmarks_focus_test.js |
| diff --git a/chrome/test/data/webui/md_bookmarks/md_bookmarks_focus_test.js b/chrome/test/data/webui/md_bookmarks/md_bookmarks_focus_test.js |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..d685e5a71b1a988b05171abe023e21e5192e811f |
| --- /dev/null |
| +++ b/chrome/test/data/webui/md_bookmarks/md_bookmarks_focus_test.js |
| @@ -0,0 +1,130 @@ |
| +// Copyright 2017 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +/** |
| + * @fileoverview Tests for MD History which are run as interactive ui tests. |
|
tsergeant
2017/05/03 03:56:38
Not "MD History" anymore...
calamity
2017/05/03 05:13:56
Done.
|
| + * Should be used for tests which care about focus. |
| + */ |
| + |
| +var ROOT_PATH = '../../../../../'; |
| + |
| +GEN_INCLUDE( |
| + [ROOT_PATH + 'chrome/test/data/webui/polymer_interactive_ui_test.js']); |
| +GEN('#include "base/command_line.h"'); |
| + |
| +function MaterialBookmarksFocusTest() {} |
| + |
| +MaterialBookmarksFocusTest.prototype = { |
| + __proto__: PolymerInteractiveUITest.prototype, |
| + |
| + browsePreload: 'chrome://bookmarks', |
| + |
| + commandLineSwitches: |
| + [{switchName: 'enable-features', switchValue: 'MaterialDesignBookmarks'}], |
| + |
| + extraLibraries: PolymerTest.getLibraries(ROOT_PATH).concat([ |
| + 'test_store.js', |
| + 'test_util.js', |
| + ]), |
| +}; |
| + |
| +TEST_F('MaterialBookmarksFocusTest', 'All', function() { |
| + suite('<bookmarks-folder-node>', function() { |
| + var rootNode; |
| + var store; |
| + |
| + function getFolderNode(id) { |
| + return findFolderNode(rootNode, id); |
| + } |
| + |
| + function keydown(id, key) { |
| + MockInteractions.keyDownOn(getFolderNode(id).$.container, '', [], key); |
| + } |
| + |
| + setup(function() { |
| + store = new bookmarks.TestStore({ |
| + nodes: testTree( |
| + createFolder( |
| + '1', |
| + [ |
| + createFolder( |
| + '2', |
| + [ |
| + createFolder('3', []), |
| + createFolder('4', []), |
| + ]), |
| + createItem('5'), |
| + ]), |
| + createFolder('7', [])), |
| + selectedFolder: '1', |
| + }); |
| + store.setReducersEnabled(true); |
| + bookmarks.Store.instance_ = store; |
| + |
| + rootNode = document.createElement('bookmarks-folder-node'); |
| + rootNode.itemId = '0'; |
| + rootNode.depth = -1; |
| + replaceBody(rootNode); |
| + Polymer.dom.flush(); |
| + }); |
| + |
| + test('keyboard selection', function() { |
| + function assertFocused(oldFocus, newFocus) { |
| + assertEquals( |
| + '', getFolderNode(oldFocus).$.container.getAttribute('tabindex')); |
| + assertEquals( |
| + '0', getFolderNode(newFocus).$.container.getAttribute('tabindex')); |
| + assertEquals( |
| + getFolderNode(newFocus).$.container, |
| + getFolderNode(newFocus).root.activeElement); |
| + } |
| + |
| + store.data.closedFolders = new Set('2'); |
| + store.notifyObservers(); |
| + |
| + // The selected folder is focus enabled on attach. |
| + assertEquals( |
| + '0', getFolderNode('1').$.container.getAttribute('tabindex')); |
| + |
| + // Only the selected folder should be focusable. |
| + assertEquals('', getFolderNode('2').$.container.getAttribute('tabindex')); |
| + |
| + // Give keyboard focus to the first item. |
| + getFolderNode('1').$.container.focus(); |
| + |
| + // Move down into child. |
| + keydown('1', 'ArrowDown'); |
| + |
| + assertDeepEquals(bookmarks.actions.selectFolder('2'), store.lastAction); |
| + assertFocused('1', '2'); |
| + |
| + // Move down past closed folders. |
| + keydown('2', 'ArrowDown'); |
| + assertDeepEquals(bookmarks.actions.selectFolder('7'), store.lastAction); |
| + assertFocused('2', '7'); |
| + |
| + // Move down past end of list. |
| + store.resetLastAction(); |
| + keydown('7', 'ArrowDown'); |
| + assertDeepEquals(null, store.lastAction); |
| + |
| + // Move up past closed folders. |
| + keydown('7', 'ArrowUp'); |
| + assertDeepEquals(bookmarks.actions.selectFolder('2'), store.lastAction); |
| + assertFocused('7', '2'); |
| + |
| + // Move up into parent. |
| + keydown('2', 'ArrowUp'); |
| + assertDeepEquals(bookmarks.actions.selectFolder('1'), store.lastAction); |
| + assertFocused('2', '1'); |
| + |
| + // Move up past start of list. |
| + store.resetLastAction(); |
| + keydown('1', 'ArrowUp'); |
| + assertDeepEquals(null, store.lastAction); |
| + }); |
| + }); |
| + |
| + mocha.run(); |
| +}); |