Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(13)

Side by Side Diff: chrome/test/data/webui/settings/android_apps_page_test.js

Issue 2873853002: arc: Handle ARC events in MD Settings (Closed)
Patch Set: comments addressed Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 /** 5 /**
6 * @constructor 6 * @constructor
7 * @implements {settings.AndroidAppsBrowserProxy} 7 * @implements {settings.AndroidAppsBrowserProxy}
8 * @extends {settings.TestBrowserProxy} 8 * @extends {settings.TestBrowserProxy}
9 */ 9 */
10 function TestAndroidAppsBrowserProxy() { 10 function TestAndroidAppsBrowserProxy() {
11 settings.TestBrowserProxy.call(this, [ 11 settings.TestBrowserProxy.call(this, [
12 'requestAndroidAppsInfo', 12 'requestAndroidAppsInfo',
13 'showAndroidAppsSettings', 13 'showAndroidAppsSettings',
14 ]); 14 ]);
15 } 15 }
16 16
17 TestAndroidAppsBrowserProxy.prototype = { 17 TestAndroidAppsBrowserProxy.prototype = {
18 __proto__: settings.TestBrowserProxy.prototype, 18 __proto__: settings.TestBrowserProxy.prototype,
19 19
20 /** @override */ 20 /** @override */
21 requestAndroidAppsInfo: function() { 21 requestAndroidAppsInfo: function() {
22 this.methodCalled('requestAndroidAppsInfo'); 22 this.methodCalled('requestAndroidAppsInfo');
23 cr.webUIListenerCallback('android-apps-info-update', {appReady: false}); 23 this.setAndroidAppsState(false, false);
24 }, 24 },
25 25
26 /** override */ 26 /** override */
27 showAndroidAppsSettings: function(keyboardAction) { 27 showAndroidAppsSettings: function(keyboardAction) {
28 this.methodCalled('showAndroidAppsSettings'); 28 this.methodCalled('showAndroidAppsSettings');
29 }, 29 },
30 30
31 setAppReady: function(ready) { 31 setAndroidAppsState: function(playStoreEnabled, settingsAppAvailable) {
32 // We need to make sure to pass a new object here, otherwise the property 32 // We need to make sure to pass a new object here, otherwise the property
33 // change event may not get fired in the listener. 33 // change event may not get fired in the listener.
34 cr.webUIListenerCallback('android-apps-info-update', {appReady: ready}); 34 var appsInfo = {
35 playStoreEnabled: playStoreEnabled,
36 settingsAppAvailable: settingsAppAvailable,
37 };
38 cr.webUIListenerCallback('android-apps-info-update', appsInfo);
35 }, 39 },
36 }; 40 };
37 41
38 /** @type {?SettingsAndroidAppsPageElement} */ 42 /** @type {?SettingsAndroidAppsPageElement} */
39 var androidAppsPage = null; 43 var androidAppsPage = null;
40 44
41 /** @type {?TestAndroidAppsBrowserProxy} */ 45 /** @type {?TestAndroidAppsBrowserProxy} */
42 var androidAppsBrowserProxy = null; 46 var androidAppsBrowserProxy = null;
43 47
44 suite('AndroidAppsPageTests', function() { 48 suite('AndroidAppsPageTests', function() {
(...skipping 10 matching lines...) Expand all
55 androidAppsPage.remove(); 59 androidAppsPage.remove();
56 }); 60 });
57 61
58 suite('Main Page', function() { 62 suite('Main Page', function() {
59 setup(function() { 63 setup(function() {
60 androidAppsPage.prefs = {arc: {enabled: {value: false}}}; 64 androidAppsPage.prefs = {arc: {enabled: {value: false}}};
61 Polymer.dom.flush(); 65 Polymer.dom.flush();
62 66
63 return androidAppsBrowserProxy.whenCalled('requestAndroidAppsInfo') 67 return androidAppsBrowserProxy.whenCalled('requestAndroidAppsInfo')
64 .then(function() { 68 .then(function() {
65 androidAppsBrowserProxy.setAppReady(false); 69 androidAppsBrowserProxy.setAndroidAppsState(false, false);
66 }); 70 });
67 }); 71 });
68 72
69 test('Enable', function() { 73 test('Enable', function() {
70 var button = androidAppsPage.$$('#enable'); 74 var button = androidAppsPage.$$('#enable');
71 assertTrue(!!button); 75 assertTrue(!!button);
72 assertFalse(!!androidAppsPage.$$('.subpage-arrow')); 76 assertFalse(!!androidAppsPage.$$('.subpage-arrow'));
73 77
74 MockInteractions.tap(button); 78 MockInteractions.tap(button);
75 Polymer.dom.flush(); 79 Polymer.dom.flush();
76 assertTrue(androidAppsPage.prefs.arc.enabled.value); 80 assertTrue(androidAppsPage.prefs.arc.enabled.value);
77 81
78 androidAppsBrowserProxy.setAppReady(true); 82 androidAppsBrowserProxy.setAndroidAppsState(true, false);
79 Polymer.dom.flush(); 83 Polymer.dom.flush();
80 assertTrue(!!androidAppsPage.$$('.subpage-arrow')); 84 assertTrue(!!androidAppsPage.$$('.subpage-arrow'));
81 }); 85 });
82 }); 86 });
83 87
84 suite('SubPage', function() { 88 suite('SubPage', function() {
85 var subpage; 89 var subpage;
86 90
91 /**
92 * Returns a new promise that resolves after a window 'popstate' event.
93 * @return {!Promise}
94 */
95 function whenPopState() {
96 return new Promise(function(resolve) {
97 window.addEventListener('popstate', function callback() {
98 window.removeEventListener('popstate', callback);
99 resolve();
100 });
101 });
102 }
103
87 setup(function() { 104 setup(function() {
88 androidAppsPage.prefs = {arc: {enabled: {value: true}}}; 105 androidAppsPage.prefs = {arc: {enabled: {value: true}}};
89 return androidAppsBrowserProxy.whenCalled('requestAndroidAppsInfo') 106 return androidAppsBrowserProxy.whenCalled('requestAndroidAppsInfo')
90 .then(function() { 107 .then(function() {
91 androidAppsBrowserProxy.setAppReady(true); 108 settings.navigateTo(settings.Route.ANDROID_APPS);
109 androidAppsBrowserProxy.setAndroidAppsState(true, false);
92 MockInteractions.tap(androidAppsPage.$$('#android-apps')); 110 MockInteractions.tap(androidAppsPage.$$('#android-apps'));
93 Polymer.dom.flush(); 111 Polymer.dom.flush();
94 subpage = androidAppsPage.$$('settings-android-apps-subpage'); 112 subpage = androidAppsPage.$$('settings-android-apps-subpage');
95 assertTrue(!!subpage); 113 assertTrue(!!subpage);
96 }); 114 });
97 }); 115 });
98 116
117 teardown(function() {
118 androidAppsPage.discardForTest();
stevenjb 2017/05/11 19:40:43 Instead of adding extra test specific code to the
stevenjb 2017/05/11 19:48:37 (Note there are 3 sub-suites, 'Main Page' 'SubPage
khmel 2017/05/11 20:26:42 Done as we discussed in chat. attached/detached
119 });
120
99 test('Sanity', function() { 121 test('Sanity', function() {
122 assertTrue(!!subpage.$$('#remove'));
100 assertTrue(!!subpage.$$('#manageApps')); 123 assertTrue(!!subpage.$$('#manageApps'));
101 assertTrue(!!subpage.$$('#remove')); 124 });
125
126 test('ManageAppsUpdate', function() {
127 var manageApps = subpage.$$('#manageApps');
128 assertTrue(manageApps.hidden);
129 androidAppsBrowserProxy.setAndroidAppsState(true, true);
130 Polymer.dom.flush();
131 assertFalse(manageApps.hidden);
132 androidAppsBrowserProxy.setAndroidAppsState(true, false);
133 Polymer.dom.flush();
134 assertTrue(manageApps.hidden);
102 }); 135 });
103 136
104 test('Disable', function() { 137 test('Disable', function() {
105 var dialog = subpage.$$('#confirmDisableDialog'); 138 var dialog = subpage.$$('#confirmDisableDialog');
106 assertTrue(!!dialog); 139 assertTrue(!!dialog);
107 assertFalse(dialog.open); 140 assertFalse(dialog.open);
108 141
109 var remove = subpage.$$('#remove'); 142 var remove = subpage.$$('#remove');
110 assertTrue(!!remove); 143 assertTrue(!!remove);
111 MockInteractions.tap(remove);
112 144
145 subpage.onRemoveTap_();
113 Polymer.dom.flush(); 146 Polymer.dom.flush();
114 assertTrue(dialog.open); 147 assertTrue(dialog.open);
115 }); 148 });
149
150 test('HideOnDisable', function() {
151 assertEquals(settings.getCurrentRoute(),
152 settings.Route.ANDROID_APPS_DETAILS);
153 androidAppsBrowserProxy.setAndroidAppsState(false, false);
154 Polymer.dom.flush();
155 return whenPopState().then(function() {
156 assertEquals(settings.getCurrentRoute(),
157 settings.Route.ANDROID_APPS);
158 });
159 });
116 }); 160 });
117 161
118 suite('Enforced', function() { 162 suite('Enforced', function() {
119 var subpage; 163 var subpage;
120 164
121 setup(function() { 165 setup(function() {
122 androidAppsPage.prefs = { 166 androidAppsPage.prefs = {
123 arc: { 167 arc: {
124 enabled: { 168 enabled: {
125 value: true, 169 value: true,
126 enforcement: chrome.settingsPrivate.Enforcement.ENFORCED 170 enforcement: chrome.settingsPrivate.Enforcement.ENFORCED
127 } 171 }
128 } 172 }
129 }; 173 };
130 return androidAppsBrowserProxy.whenCalled('requestAndroidAppsInfo') 174 return androidAppsBrowserProxy.whenCalled('requestAndroidAppsInfo')
131 .then(function() { 175 .then(function() {
132 androidAppsBrowserProxy.setAppReady(true); 176 androidAppsBrowserProxy.setAndroidAppsState(true, true);
133 MockInteractions.tap(androidAppsPage.$$('#android-apps')); 177 MockInteractions.tap(androidAppsPage.$$('#android-apps'));
134 Polymer.dom.flush(); 178 Polymer.dom.flush();
135 subpage = androidAppsPage.$$('settings-android-apps-subpage'); 179 subpage = androidAppsPage.$$('settings-android-apps-subpage');
136 assertTrue(!!subpage); 180 assertTrue(!!subpage);
137 }); 181 });
138 }); 182 });
139 183
140 test('Sanity', function() { 184 test('Sanity', function() {
141 Polymer.dom.flush(); 185 Polymer.dom.flush();
142 assertTrue(!!subpage.$$('#manageApps')); 186 assertTrue(!!subpage.$$('#manageApps'));
143 assertFalse(!!subpage.$$('#remove')); 187 assertFalse(!!subpage.$$('#remove'));
144 }); 188 });
145 }); 189 });
146 }); 190 });
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698