OLD | NEW |
---|---|
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 Loading... | |
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 }); |
OLD | NEW |