Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 1 | <!DOCTYPE html> |
| 2 | <!-- |
| 3 | Copyright (C) 2015 The Android Open Source Project |
| 4 | |
| 5 | Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | you may not use this file except in compliance with the License. |
| 7 | You may obtain a copy of the License at |
| 8 | |
| 9 | http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | |
| 11 | Unless required by applicable law or agreed to in writing, software |
| 12 | distributed under the License is distributed on an "AS IS" BASIS, |
| 13 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | See the License for the specific language governing permissions and |
| 15 | limitations under the License. |
| 16 | --> |
| 17 | |
| 18 | <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes"> |
Andrew Bonventre | 882043f | 2016-02-22 18:12:27 -0500 | [diff] [blame] | 19 | <title>gr-reply-dialog</title> |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 20 | |
Viktar Donich | 29e1ce5 | 2017-03-28 17:02:44 -0700 | [diff] [blame] | 21 | <script src="../../../bower_components/webcomponentsjs/webcomponents-lite.min.js"></script> |
Andrew Bonventre | 78792e8 | 2016-03-04 17:48:22 -0500 | [diff] [blame] | 22 | <script src="../../../bower_components/web-component-tester/browser.js"></script> |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 23 | |
Andrew Bonventre | 78792e8 | 2016-03-04 17:48:22 -0500 | [diff] [blame] | 24 | <link rel="import" href="../../../bower_components/iron-test-helpers/iron-test-helpers.html"> |
| 25 | <link rel="import" href="gr-reply-dialog.html"> |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 26 | |
Viktar Donich | 29e1ce5 | 2017-03-28 17:02:44 -0700 | [diff] [blame] | 27 | <script>void(0);</script> |
| 28 | |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 29 | <test-fixture id="basic"> |
| 30 | <template> |
Andrew Bonventre | 882043f | 2016-02-22 18:12:27 -0500 | [diff] [blame] | 31 | <gr-reply-dialog></gr-reply-dialog> |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 32 | </template> |
| 33 | </test-fixture> |
| 34 | |
| 35 | <script> |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 36 | suite('gr-reply-dialog tests', () => { |
| 37 | let element; |
| 38 | let changeNum; |
| 39 | let patchNum; |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 40 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 41 | let sandbox; |
| 42 | let getDraftCommentStub; |
| 43 | let setDraftCommentStub; |
| 44 | let eraseDraftCommentStub; |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 45 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 46 | let lastId = 0; |
| 47 | const makeAccount = function() { return {_account_id: lastId++}; }; |
| 48 | const makeGroup = function() { return {id: lastId++}; }; |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 49 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 50 | setup(() => { |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 51 | sandbox = sinon.sandbox.create(); |
| 52 | |
| 53 | changeNum = 42; |
| 54 | patchNum = 1; |
| 55 | |
Andrew Bonventre | 5c09ba9 | 2016-05-02 17:31:23 -0400 | [diff] [blame] | 56 | stub('gr-rest-api-interface', { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 57 | getConfig() { return Promise.resolve({}); }, |
| 58 | getAccount() { return Promise.resolve({}); }, |
Andrew Bonventre | cfacb80 | 2016-03-29 14:06:39 -0400 | [diff] [blame] | 59 | }); |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 60 | |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 61 | element = fixture('basic'); |
Kasper Nilsson | 352b68f | 2016-10-11 11:51:35 -0700 | [diff] [blame] | 62 | element.change = { |
| 63 | _number: changeNum, |
| 64 | labels: { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 65 | 'Verified': { |
Kasper Nilsson | 352b68f | 2016-10-11 11:51:35 -0700 | [diff] [blame] | 66 | values: { |
| 67 | '-1': 'Fails', |
| 68 | ' 0': 'No score', |
| 69 | '+1': 'Verified', |
| 70 | }, |
| 71 | default_value: 0, |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 72 | }, |
Kasper Nilsson | 352b68f | 2016-10-11 11:51:35 -0700 | [diff] [blame] | 73 | 'Code-Review': { |
| 74 | values: { |
| 75 | '-2': 'Do not submit', |
| 76 | '-1': 'I would prefer that you didn\'t submit this', |
| 77 | ' 0': 'No score', |
| 78 | '+1': 'Looks good to me, but someone else must approve', |
| 79 | '+2': 'Looks good to me, approved', |
| 80 | }, |
| 81 | default_value: 0, |
| 82 | }, |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 83 | }, |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 84 | }; |
Kasper Nilsson | 352b68f | 2016-10-11 11:51:35 -0700 | [diff] [blame] | 85 | element.patchNum = patchNum; |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 86 | element.permittedLabels = { |
| 87 | 'Code-Review': [ |
| 88 | '-1', |
| 89 | ' 0', |
Kasper Nilsson | 352b68f | 2016-10-11 11:51:35 -0700 | [diff] [blame] | 90 | '+1', |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 91 | ], |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 92 | 'Verified': [ |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 93 | '-1', |
| 94 | ' 0', |
Kasper Nilsson | 352b68f | 2016-10-11 11:51:35 -0700 | [diff] [blame] | 95 | '+1', |
| 96 | ], |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 97 | }; |
Logan Hanks | a75fb05 | 2016-08-01 13:23:38 -0700 | [diff] [blame] | 98 | element.serverConfig = {}; |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 99 | |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 100 | getDraftCommentStub = sandbox.stub(element.$.storage, 'getDraftComment'); |
| 101 | setDraftCommentStub = sandbox.stub(element.$.storage, 'setDraftComment'); |
| 102 | eraseDraftCommentStub = sandbox.stub(element.$.storage, |
| 103 | 'eraseDraftComment'); |
| 104 | |
Wyatt Allen | 6cf5875 | 2017-04-24 16:59:07 +0200 | [diff] [blame] | 105 | sandbox.stub(element, 'fetchIsLatestKnown', |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 106 | () => { return Promise.resolve(true); }); |
Wyatt Allen | 6cf5875 | 2017-04-24 16:59:07 +0200 | [diff] [blame] | 107 | |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 108 | // Allow the elements created by dom-repeat to be stamped. |
| 109 | flushAsynchronousOperations(); |
| 110 | }); |
| 111 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 112 | teardown(() => { |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 113 | sandbox.restore(); |
| 114 | }); |
| 115 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 116 | test('default to publishing drafts with reply', done => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 117 | // Async tick is needed because iron-selector content is distributed and |
| 118 | // distributed content requires an observer to be set up. |
| 119 | // Note: Double flush seems to be needed in Safari. {@see Issue 4963}. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 120 | flush(() => { |
| 121 | flush(() => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 122 | element.draft = 'I wholeheartedly disapprove'; |
| 123 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 124 | sandbox.stub(element, '_saveReview', review => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 125 | assert.deepEqual(review, { |
| 126 | drafts: 'PUBLISH_ALL_REVISIONS', |
| 127 | labels: {}, |
| 128 | message: 'I wholeheartedly disapprove', |
| 129 | reviewers: [], |
| 130 | }); |
| 131 | assert.isFalse(element.$.commentList.hidden); |
| 132 | done(); |
| 133 | return Promise.resolve({ok: true}); |
| 134 | }); |
| 135 | |
| 136 | // This is needed on non-Blink engines most likely due to the ways in |
| 137 | // which the dom-repeat elements are stamped. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 138 | flush(() => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 139 | MockInteractions.tap(element.$$('.send')); |
| 140 | }); |
| 141 | }); |
| 142 | }); |
| 143 | }); |
| 144 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 145 | test('keep drafts with reply', done => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 146 | MockInteractions.tap(element.$$('#includeComments')); |
| 147 | assert.equal(element._includeComments, false); |
| 148 | |
| 149 | // Async tick is needed because iron-selector content is distributed and |
| 150 | // distributed content requires an observer to be set up. |
| 151 | // Note: Double flush seems to be needed in Safari. {@see Issue 4963}. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 152 | flush(() => { |
| 153 | flush(() => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 154 | element.draft = 'I wholeheartedly disapprove'; |
| 155 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 156 | sandbox.stub(element, '_saveReview', review => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 157 | assert.deepEqual(review, { |
| 158 | drafts: 'KEEP', |
| 159 | labels: {}, |
| 160 | message: 'I wholeheartedly disapprove', |
| 161 | reviewers: [], |
| 162 | }); |
| 163 | assert.isTrue(element.$.commentList.hidden); |
| 164 | done(); |
| 165 | return Promise.resolve({ok: true}); |
| 166 | }); |
| 167 | |
| 168 | // This is needed on non-Blink engines most likely due to the ways in |
| 169 | // which the dom-repeat elements are stamped. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 170 | flush(() => { |
Becky Siegel | 9efcd57 | 2017-03-23 08:28:03 -0700 | [diff] [blame] | 171 | MockInteractions.tap(element.$$('.send')); |
| 172 | }); |
| 173 | }); |
| 174 | }); |
| 175 | }); |
| 176 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 177 | test('label picker', done => { |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 178 | element.draft = 'I wholeheartedly disapprove'; |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 179 | sandbox.stub(element, '_saveReview', review => { |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 180 | assert.deepEqual(review, { |
| 181 | drafts: 'PUBLISH_ALL_REVISIONS', |
| 182 | labels: { |
| 183 | 'Code-Review': -1, |
| 184 | 'Verified': -1, |
| 185 | }, |
| 186 | message: 'I wholeheartedly disapprove', |
| 187 | reviewers: [], |
Urs Wolfer | b603694 | 2016-03-06 14:57:02 +0100 | [diff] [blame] | 188 | }); |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 189 | return Promise.resolve({ok: true}); |
| 190 | }); |
| 191 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 192 | sandbox.stub(element.$.labelScores, 'getLabelValues', () => { |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 193 | return { |
| 194 | 'Code-Review': -1, |
| 195 | 'Verified': -1, |
| 196 | }; |
| 197 | }); |
| 198 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 199 | element.addEventListener('send', () => { |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 200 | assert.isFalse(element.disabled, |
| 201 | 'Element should be enabled when done sending reply.'); |
| 202 | assert.equal(element.draft.length, 0); |
| 203 | done(); |
| 204 | }); |
| 205 | |
| 206 | // This is needed on non-Blink engines most likely due to the ways in |
| 207 | // which the dom-repeat elements are stamped. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 208 | flush(() => { |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 209 | MockInteractions.tap(element.$$('.send')); |
| 210 | assert.isTrue(element.disabled); |
Urs Wolfer | b603694 | 2016-03-06 14:57:02 +0100 | [diff] [blame] | 211 | }); |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 212 | }); |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 213 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 214 | test('setlabelValue', () => { |
Becky Siegel | 452a5c6 | 2017-05-09 09:59:55 -0700 | [diff] [blame] | 215 | element._account = {_account_id: 1}; |
| 216 | flushAsynchronousOperations(); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 217 | const label = 'Verified'; |
| 218 | const value = '+1'; |
Becky Siegel | 452a5c6 | 2017-05-09 09:59:55 -0700 | [diff] [blame] | 219 | element.setLabelValue(label, value); |
| 220 | flushAsynchronousOperations(); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 221 | const labels = element.$.labelScores.getLabelValues(); |
| 222 | assert.deepEqual(labels, {Verified: 1}); |
Becky Siegel | 452a5c6 | 2017-05-09 09:59:55 -0700 | [diff] [blame] | 223 | }); |
| 224 | |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 225 | function getActiveElement() { |
| 226 | return Polymer.IronOverlayManager.deepActiveElement; |
| 227 | } |
| 228 | |
| 229 | function isVisible(el) { |
| 230 | assert.ok(el); |
| 231 | return getComputedStyle(el).getPropertyValue('display') != 'none'; |
| 232 | } |
| 233 | |
| 234 | function overlayObserver(mode) { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 235 | return new Promise(resolve => { |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 236 | function listener() { |
| 237 | element.removeEventListener('iron-overlay-' + mode, listener); |
| 238 | resolve(); |
| 239 | } |
| 240 | element.addEventListener('iron-overlay-' + mode, listener); |
| 241 | }); |
| 242 | } |
| 243 | |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 244 | function testConfirmationDialog(done, cc) { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 245 | const yesButton = |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 246 | element.$$('.reviewerConfirmationButtons gr-button:first-child'); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 247 | const noButton = |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 248 | element.$$('.reviewerConfirmationButtons gr-button:last-child'); |
| 249 | |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 250 | element.serverConfig = {note_db_enabled: true}; |
| 251 | element._ccPendingConfirmation = null; |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 252 | element._reviewerPendingConfirmation = null; |
| 253 | flushAsynchronousOperations(); |
| 254 | assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay)); |
| 255 | |
| 256 | // Cause the confirmation dialog to display. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 257 | let observer = overlayObserver('opened'); |
| 258 | const group = { |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 259 | id: 'id', |
| 260 | name: 'name', |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 261 | }; |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 262 | if (cc) { |
| 263 | element._ccPendingConfirmation = { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 264 | group, |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 265 | count: 10, |
| 266 | }; |
| 267 | } else { |
| 268 | element._reviewerPendingConfirmation = { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 269 | group, |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 270 | count: 10, |
| 271 | }; |
| 272 | } |
| 273 | flushAsynchronousOperations(); |
| 274 | |
| 275 | if (cc) { |
| 276 | assert.deepEqual( |
| 277 | element._ccPendingConfirmation, |
| 278 | element._pendingConfirmationDetails); |
| 279 | } else { |
| 280 | assert.deepEqual( |
| 281 | element._reviewerPendingConfirmation, |
| 282 | element._pendingConfirmationDetails); |
| 283 | } |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 284 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 285 | observer.then(() => { |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 286 | assert.isTrue(isVisible(element.$.reviewerConfirmationOverlay)); |
| 287 | observer = overlayObserver('closed'); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 288 | const expected = 'Group name has 10 members'; |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 289 | assert.notEqual( |
| 290 | element.$.reviewerConfirmationOverlay.innerText.indexOf(expected), |
| 291 | -1); |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 292 | MockInteractions.tap(noButton); // close the overlay |
| 293 | return observer; |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 294 | }).then(() => { |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 295 | assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay)); |
| 296 | |
| 297 | // We should be focused on account entry input. |
| 298 | assert.equal(getActiveElement().id, 'input'); |
| 299 | |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 300 | // No reviewer/CC should have been added. |
| 301 | assert.equal(element.$$('#ccs').additions().length, 0); |
| 302 | assert.equal(element.$.reviewers.additions().length, 0); |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 303 | |
| 304 | // Reopen confirmation dialog. |
| 305 | observer = overlayObserver('opened'); |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 306 | if (cc) { |
| 307 | element._ccPendingConfirmation = { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 308 | group, |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 309 | count: 10, |
| 310 | }; |
| 311 | } else { |
| 312 | element._reviewerPendingConfirmation = { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 313 | group, |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 314 | count: 10, |
| 315 | }; |
| 316 | } |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 317 | return observer; |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 318 | }).then(() => { |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 319 | assert.isTrue(isVisible(element.$.reviewerConfirmationOverlay)); |
| 320 | observer = overlayObserver('closed'); |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 321 | MockInteractions.tap(yesButton); // Confirm the group. |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 322 | return observer; |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 323 | }).then(() => { |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 324 | assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay)); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 325 | const additions = cc ? |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 326 | element.$$('#ccs').additions() : |
| 327 | element.$.reviewers.additions(); |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 328 | assert.deepEqual( |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 329 | additions, |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 330 | [ |
| 331 | { |
| 332 | group: { |
| 333 | id: 'id', |
| 334 | name: 'name', |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 335 | confirmed: true, |
| 336 | _group: true, |
| 337 | _pendingAdd: true, |
| 338 | }, |
| 339 | }, |
| 340 | ]); |
| 341 | |
| 342 | // We should be focused on account entry input. |
| 343 | assert.equal(getActiveElement().id, 'input'); |
| 344 | }).then(done); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 345 | } |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 346 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 347 | test('cc confirmation', done => { |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 348 | testConfirmationDialog(done, true); |
| 349 | }); |
| 350 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 351 | test('reviewer confirmation', done => { |
Logan Hanks | 43d4dbb | 2016-12-14 18:17:47 -0800 | [diff] [blame] | 352 | testConfirmationDialog(done, false); |
Logan Hanks | a008aa9 | 2016-07-22 10:31:12 -0700 | [diff] [blame] | 353 | }); |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 354 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 355 | test('_getStorageLocation', () => { |
| 356 | const actual = element._getStorageLocation(); |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 357 | assert.equal(actual.changeNum, changeNum); |
| 358 | assert.equal(actual.patchNum, patchNum); |
| 359 | assert.equal(actual.path, '@change'); |
| 360 | }); |
| 361 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 362 | test('gets draft from storage on open', () => { |
| 363 | const storedDraft = 'hello world'; |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 364 | getDraftCommentStub.returns({message: storedDraft}); |
| 365 | element.open(); |
| 366 | assert.isTrue(getDraftCommentStub.called); |
| 367 | assert.equal(element.draft, storedDraft); |
| 368 | }); |
| 369 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 370 | test('blank if no stored draft', () => { |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 371 | getDraftCommentStub.returns(null); |
| 372 | element.open(); |
| 373 | assert.isTrue(getDraftCommentStub.called); |
| 374 | assert.equal(element.draft, ''); |
| 375 | }); |
| 376 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 377 | test('updates stored draft on edits', () => { |
| 378 | const firstEdit = 'hello'; |
| 379 | const location = element._getStorageLocation(); |
Wyatt Allen | 4f4b3a7 | 2016-07-28 12:05:53 -0700 | [diff] [blame] | 380 | |
| 381 | element.draft = firstEdit; |
| 382 | element.flushDebouncer('store'); |
| 383 | |
| 384 | assert.isTrue(setDraftCommentStub.calledWith(location, firstEdit)); |
| 385 | |
| 386 | element.draft = ''; |
| 387 | element.flushDebouncer('store'); |
| 388 | |
| 389 | assert.isTrue(eraseDraftCommentStub.calledWith(location)); |
| 390 | }); |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 391 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 392 | test('400 converts to human-readable server-error', done => { |
| 393 | sandbox.stub(window, 'fetch', () => { |
| 394 | const text = '....{"reviewers":{"id1":{"error":"first error"}},' + |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 395 | '"ccs":{"id2":{"error":"second error"}}}'; |
| 396 | return Promise.resolve({ |
| 397 | ok: false, |
| 398 | status: 400, |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 399 | text() { return Promise.resolve(text); }, |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 400 | }); |
| 401 | }); |
| 402 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 403 | element.addEventListener('server-error', event => { |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 404 | if (event.target !== element) { |
| 405 | return; |
| 406 | } |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 407 | event.detail.response.text().then(body => { |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 408 | assert.equal(body, 'first error, second error'); |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 409 | }); |
| 410 | }); |
Andrew Bonventre | efd0a53 | 2016-08-23 17:04:23 -0400 | [diff] [blame] | 411 | |
| 412 | // Async tick is needed because iron-selector content is distributed and |
| 413 | // distributed content requires an observer to be set up. |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 414 | flush(() => { element.send().then(done); }); |
Logan Hanks | a75fb05 | 2016-08-01 13:23:38 -0700 | [diff] [blame] | 415 | }); |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 416 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 417 | test('ccs are displayed if NoteDb is enabled', () => { |
Logan Hanks | a75fb05 | 2016-08-01 13:23:38 -0700 | [diff] [blame] | 418 | function hasCc() { |
| 419 | flushAsynchronousOperations(); |
| 420 | return !!element.$$('#ccs'); |
| 421 | } |
| 422 | |
| 423 | element.serverConfig = {}; |
| 424 | assert.isFalse(hasCc()); |
| 425 | |
| 426 | element.serverConfig = {note_db_enabled: true}; |
| 427 | assert.isTrue(hasCc()); |
| 428 | }); |
| 429 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 430 | test('filterReviewerSuggestion', () => { |
| 431 | const owner = makeAccount(); |
| 432 | const reviewer1 = makeAccount(); |
| 433 | const reviewer2 = makeGroup(); |
| 434 | const cc1 = makeAccount(); |
| 435 | const cc2 = makeGroup(); |
Logan Hanks | a75fb05 | 2016-08-01 13:23:38 -0700 | [diff] [blame] | 436 | |
| 437 | element._owner = owner; |
| 438 | element._reviewers = [reviewer1, reviewer2]; |
| 439 | element._ccs = [cc1, cc2]; |
| 440 | |
| 441 | assert.isTrue( |
| 442 | element._filterReviewerSuggestion({account: makeAccount()})); |
| 443 | assert.isTrue(element._filterReviewerSuggestion({group: makeGroup()})); |
| 444 | |
| 445 | // Owner should be excluded. |
| 446 | assert.isFalse(element._filterReviewerSuggestion({account: owner})); |
| 447 | |
| 448 | // Existing and pending reviewers should be excluded. |
| 449 | assert.isFalse(element._filterReviewerSuggestion({account: reviewer1})); |
| 450 | assert.isFalse(element._filterReviewerSuggestion({group: reviewer2})); |
| 451 | |
| 452 | // Existing and pending CCs should be excluded. |
| 453 | assert.isFalse(element._filterReviewerSuggestion({account: cc1})); |
| 454 | assert.isFalse(element._filterReviewerSuggestion({group: cc2})); |
Logan Hanks | f1063a2 | 2016-07-22 16:05:04 -0700 | [diff] [blame] | 455 | }); |
Logan Hanks | fc57acc | 2016-08-05 13:54:50 -0700 | [diff] [blame] | 456 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 457 | test('_chooseFocusTarget', () => { |
Logan Hanks | fc57acc | 2016-08-05 13:54:50 -0700 | [diff] [blame] | 458 | element._account = null; |
| 459 | assert.strictEqual( |
| 460 | element._chooseFocusTarget(), element.FocusTarget.BODY); |
| 461 | |
| 462 | element._account = {_account_id: 1}; |
| 463 | assert.strictEqual( |
| 464 | element._chooseFocusTarget(), element.FocusTarget.BODY); |
| 465 | |
| 466 | element.change.owner = {_account_id: 2}; |
| 467 | assert.strictEqual( |
| 468 | element._chooseFocusTarget(), element.FocusTarget.BODY); |
| 469 | |
| 470 | element.change.owner._account_id = 1; |
| 471 | element.change._reviewers = null; |
| 472 | assert.strictEqual( |
| 473 | element._chooseFocusTarget(), element.FocusTarget.REVIEWERS); |
| 474 | |
| 475 | element._reviewers = []; |
| 476 | assert.strictEqual( |
| 477 | element._chooseFocusTarget(), element.FocusTarget.REVIEWERS); |
| 478 | |
| 479 | element._reviewers.push({}); |
| 480 | assert.strictEqual( |
| 481 | element._chooseFocusTarget(), element.FocusTarget.BODY); |
| 482 | }); |
Logan Hanks | ca3c497 | 2016-09-14 16:25:56 -0700 | [diff] [blame] | 483 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 484 | test('only send labels that have changed', done => { |
| 485 | flush(() => { |
| 486 | sandbox.stub(element, '_saveReview', review => { |
Kasper Nilsson | 4416acd | 2016-09-16 13:27:11 -0700 | [diff] [blame] | 487 | assert.deepEqual(review.labels, {Verified: -1}); |
| 488 | return Promise.resolve({ok: true}); |
| 489 | }); |
Logan Hanks | ca3c497 | 2016-09-14 16:25:56 -0700 | [diff] [blame] | 490 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 491 | element.addEventListener('send', () => { |
Kasper Nilsson | 4416acd | 2016-09-16 13:27:11 -0700 | [diff] [blame] | 492 | done(); |
| 493 | }); |
| 494 | // Without wrapping this test in flush(), the below two calls to |
| 495 | // MockInteractions.tap() cause a race in some situations in shadow DOM. |
| 496 | // The send button can be tapped before the others, causing the test to |
| 497 | // fail. |
Becky Siegel | a499e3d | 2017-04-06 16:57:13 -0700 | [diff] [blame] | 498 | |
| 499 | MockInteractions.tap(element.$$('gr-label-scores').$$( |
Kasper Nilsson | 4416acd | 2016-09-16 13:27:11 -0700 | [diff] [blame] | 500 | 'iron-selector[data-label="Verified"] > ' + |
| 501 | 'gr-button[data-value="-1"]')); |
| 502 | MockInteractions.tap(element.$$('.send')); |
Logan Hanks | ca3c497 | 2016-09-14 16:25:56 -0700 | [diff] [blame] | 503 | }); |
Logan Hanks | ca3c497 | 2016-09-14 16:25:56 -0700 | [diff] [blame] | 504 | }); |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 505 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 506 | test('do not display tooltips on touch devices', () => { |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 507 | element._account = {_account_id: 1}; |
| 508 | element.set(['change', 'labels', 'Verified', 'all'], |
| 509 | [{_account_id: 1, value: -1}]); |
| 510 | element.labels = { |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 511 | 'Verified': { |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 512 | values: { |
| 513 | '-1': 'Fails', |
| 514 | ' 0': 'No score', |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 515 | '+1': 'Verified', |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 516 | }, |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 517 | default_value: 0, |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 518 | }, |
| 519 | 'Code-Review': { |
| 520 | values: { |
| 521 | '-2': 'Do not submit', |
| 522 | '-1': 'I would prefer that you didn\'t submit this', |
| 523 | ' 0': 'No score', |
| 524 | '+1': 'Looks good to me, but someone else must approve', |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 525 | '+2': 'Looks good to me, approved', |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 526 | }, |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 527 | default_value: 0, |
| 528 | }, |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 529 | }; |
| 530 | |
| 531 | flushAsynchronousOperations(); |
| 532 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 533 | const verifiedBtn = element.$$('gr-label-scores').$$( |
Becky Siegel | 8bb0934 | 2016-10-17 17:49:31 -0700 | [diff] [blame] | 534 | 'iron-selector[data-label="Verified"] > ' + |
| 535 | 'gr-button[data-value="-1"]'); |
| 536 | |
| 537 | // On touch devices, tooltips should not be shown. |
| 538 | verifiedBtn._isTouchDevice = true; |
| 539 | verifiedBtn._handleShowTooltip(); |
| 540 | assert.isNotOk(verifiedBtn._tooltip); |
| 541 | verifiedBtn._handleHideTooltip(); |
| 542 | assert.isNotOk(verifiedBtn._tooltip); |
| 543 | |
| 544 | // On other devices, tooltips should be shown. |
| 545 | verifiedBtn._isTouchDevice = false; |
| 546 | verifiedBtn._handleShowTooltip(); |
| 547 | assert.isOk(verifiedBtn._tooltip); |
| 548 | verifiedBtn._handleHideTooltip(); |
| 549 | assert.isNotOk(verifiedBtn._tooltip); |
| 550 | }); |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 551 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 552 | test('_processReviewerChange', () => { |
| 553 | const mockIndexSplices = function(toRemove) { |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 554 | return [{ |
| 555 | removed: [toRemove], |
| 556 | }]; |
| 557 | }; |
| 558 | |
| 559 | element._processReviewerChange( |
| 560 | mockIndexSplices(makeAccount()), 'REVIEWER'); |
| 561 | assert.equal(element._reviewersPendingRemove.REVIEWER.length, 1); |
| 562 | }); |
| 563 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 564 | test('_purgeReviewersPendingRemove', () => { |
| 565 | const removeStub = sandbox.stub(element, '_removeAccount'); |
| 566 | const mock = function() { |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 567 | element._reviewersPendingRemove = { |
| 568 | test: [makeAccount()], |
| 569 | test2: [makeAccount(), makeAccount()], |
| 570 | }; |
| 571 | }; |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 572 | const checkObjEmpty = function(obj) { |
| 573 | for (const prop in obj) { |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 574 | if (obj.hasOwnProperty(prop) && obj[prop].length) { return false; } |
| 575 | } |
| 576 | return true; |
| 577 | }; |
| 578 | mock(); |
| 579 | element._purgeReviewersPendingRemove(true); // Cancel |
| 580 | assert.isFalse(removeStub.called); |
| 581 | assert.isTrue(checkObjEmpty(element._reviewersPendingRemove)); |
| 582 | |
| 583 | mock(); |
| 584 | element._purgeReviewersPendingRemove(false); // Submit |
| 585 | assert.isTrue(removeStub.called); |
| 586 | assert.isTrue(checkObjEmpty(element._reviewersPendingRemove)); |
| 587 | }); |
| 588 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 589 | test('_removeAccount', done => { |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 590 | sandbox.stub(element.$.restAPI, 'removeChangeReviewer') |
| 591 | .returns(Promise.resolve({ok: true})); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 592 | const arr = [makeAccount(), makeAccount()]; |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 593 | element.change.reviewers = { |
| 594 | REVIEWER: arr.slice(), |
| 595 | }; |
| 596 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 597 | element._removeAccount(arr[1], 'REVIEWER').then(() => { |
Kasper Nilsson | a827155 | 2017-01-17 11:54:40 -0800 | [diff] [blame] | 598 | assert.equal(element.change.reviewers.REVIEWER.length, 1); |
| 599 | assert.deepEqual(element.change.reviewers.REVIEWER, arr.slice(0, 1)); |
| 600 | done(); |
| 601 | }); |
| 602 | }); |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 603 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 604 | test('migrate reviewers between states', done => { |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 605 | element.serverConfig = {note_db_enabled: true}; |
| 606 | element._reviewersPendingRemove = { |
| 607 | CC: [], |
| 608 | REVIEWER: [], |
| 609 | }; |
| 610 | flushAsynchronousOperations(); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 611 | const reviewers = element.$.reviewers; |
| 612 | const ccs = element.$$('#ccs'); |
| 613 | const reviewer1 = makeAccount(); |
| 614 | const reviewer2 = makeAccount(); |
| 615 | const cc1 = makeAccount(); |
| 616 | const cc2 = makeAccount(); |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 617 | element._reviewers = [reviewer1, reviewer2]; |
| 618 | element._ccs = [cc1, cc2]; |
| 619 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 620 | const mutations = []; |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 621 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 622 | sandbox.stub(element, '_saveReview', review => { |
| 623 | mutations.push(...review.reviewers); |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 624 | return Promise.resolve({ok: true}); |
| 625 | }); |
| 626 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 627 | sandbox.stub(element, '_removeAccount', (account, type) => { |
| 628 | mutations.push({state: 'REMOVED', account}); |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 629 | return Promise.resolve(); |
| 630 | }); |
| 631 | |
| 632 | // Remove and add to other field. |
| 633 | reviewers.fire('remove', {account: reviewer1}); |
| 634 | ccs.$.entry.fire('add', {value: {account: reviewer1}}); |
| 635 | ccs.fire('remove', {account: cc1}); |
| 636 | reviewers.$.entry.fire('add', {value: {account: cc1}}); |
| 637 | |
| 638 | // Add to other field without removing from former field. |
| 639 | // (Currently not possible in UI, but this is a good consistency check). |
| 640 | reviewers.$.entry.fire('add', {value: {account: cc2}}); |
| 641 | ccs.$.entry.fire('add', {value: {account: reviewer2}}); |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 642 | const mapReviewer = function(reviewer, opt_state) { |
| 643 | const result = {reviewer: reviewer._account_id, confirmed: undefined}; |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 644 | if (opt_state) { |
| 645 | result.state = opt_state; |
| 646 | } |
| 647 | return result; |
| 648 | }; |
| 649 | |
| 650 | // Send and purge and verify moves without deletions. |
| 651 | element.send() |
| 652 | .then(element._purgeReviewersPendingRemove.bind(element)) |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 653 | .then(() => { |
| 654 | assert.deepEqual( |
| 655 | mutations, [ |
| 656 | mapReviewer(cc1), |
| 657 | mapReviewer(cc2), |
| 658 | mapReviewer(reviewer1, 'CC'), |
| 659 | mapReviewer(reviewer2, 'CC'), |
| 660 | ]); |
| 661 | done(); |
| 662 | }); |
Logan Hanks | 64451c0 | 2017-03-22 13:39:40 -0700 | [diff] [blame] | 663 | }); |
Kasper Nilsson | ff0745d | 2017-03-21 16:41:24 -0700 | [diff] [blame] | 664 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 665 | test('emits cancel on esc key', () => { |
| 666 | const cancelHandler = sandbox.spy(); |
Kasper Nilsson | ff0745d | 2017-03-21 16:41:24 -0700 | [diff] [blame] | 667 | element.addEventListener('cancel', cancelHandler); |
| 668 | MockInteractions.pressAndReleaseKeyOn(element, 27, null, 'esc'); |
| 669 | flushAsynchronousOperations(); |
| 670 | |
| 671 | assert.isTrue(cancelHandler.called); |
| 672 | }); |
Logan Hanks | dc65dde | 2017-04-27 11:45:23 +0200 | [diff] [blame] | 673 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 674 | test('_computeMessagePlaceholder', () => { |
Logan Hanks | dc65dde | 2017-04-27 11:45:23 +0200 | [diff] [blame] | 675 | assert.equal( |
| 676 | element._computeMessagePlaceholder(false), |
| 677 | 'Say something nice...'); |
| 678 | assert.equal( |
| 679 | element._computeMessagePlaceholder(true), |
| 680 | 'Add a note for your reviewers...'); |
| 681 | }); |
| 682 | |
Kasper Nilsson | ad908b1 | 2017-05-11 11:26:10 -0700 | [diff] [blame] | 683 | test('_computeSendButtonLabel', () => { |
Logan Hanks | dc65dde | 2017-04-27 11:45:23 +0200 | [diff] [blame] | 684 | assert.equal( |
| 685 | element._computeSendButtonLabel(false), |
| 686 | 'Send'); |
| 687 | assert.equal( |
| 688 | element._computeSendButtonLabel(true), |
| 689 | 'Start review'); |
| 690 | }); |
Andrew Bonventre | f8b026d | 2015-12-09 17:55:54 -0500 | [diff] [blame] | 691 | }); |
| 692 | </script> |