 49d0a6e10d
			
		
	
	49d0a6e10d
	
	
	
		
			
			in this change: - add "Show Fix" option to gr-comment when fixes exist - add GET /preview and POST /apply endpoints to gr-rest-api-interface - create gr-apply-fix-dialog that fetch preview and supports showing multiple diffs for a single fix, apply fix button that navigate to edit-change view, and cancel that close dialog Screenshots: https://imgur.com/a/6xQIoz8 next: - support switching between multiple fixes Change-Id: I9ba5121dd3b5b51791540ac9758f98c8669b44b2
		
			
				
	
	
		
			144 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <!--
 | |
| @license
 | |
| Copyright (C) 2019 The Android Open Source Project
 | |
| 
 | |
| Licensed under the Apache License, Version 2.0 (the 'License');
 | |
| you may not use this file except in compliance with the License.
 | |
| You may obtain a copy of the License at
 | |
| 
 | |
| http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
| Unless required by applicable law or agreed to in writing, software
 | |
| distributed under the License is distributed on an 'AS IS' BASIS,
 | |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| See the License for the specific language governing permissions and
 | |
| limitations under the License.
 | |
| -->
 | |
| <meta name='viewport' content='width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes'>
 | |
| <title>gr-apply-fix-dialog</title>
 | |
| <script src='/test/common-test-setup.js'></script>
 | |
| <script src='/bower_components/webcomponentsjs/custom-elements-es5-adapter.js'></script>
 | |
| 
 | |
| <script src='/bower_components/webcomponentsjs/webcomponents-lite.js'></script>
 | |
| <script src='/bower_components/web-component-tester/browser.js'></script>
 | |
| <link rel='import' href='../../../test/common-test-setup.html' />
 | |
| 
 | |
| <link rel='import' href='./gr-apply-fix-dialog.html'>
 | |
| 
 | |
| <script>void (0);</script>
 | |
| 
 | |
| <test-fixture id='basic'>
 | |
|   <template>
 | |
|     <gr-apply-fix-dialog></gr-apply-fix-dialog>
 | |
|   </template>
 | |
| </test-fixture>
 | |
| 
 | |
| <script>
 | |
|   suite('gr-apply-fix-dialog tests', () => {
 | |
|     let element;
 | |
|     let sandbox;
 | |
|     const ROBOT_COMMENT = {
 | |
|       robot_id: 'robot_1',
 | |
|       fix_suggestions: [{fix_id: 'fix_1'}],
 | |
|     };
 | |
| 
 | |
|     setup(() => {
 | |
|       sandbox = sinon.sandbox.create();
 | |
|       element = fixture('basic');
 | |
|       element.changeNum = '1';
 | |
|       element._patchNum = 2;
 | |
|       element.change = {
 | |
|         _number: '1',
 | |
|         project: 'project',
 | |
|       };
 | |
|       element.prefs = {
 | |
|         font_size: 12,
 | |
|         line_length: 100,
 | |
|         tab_size: 4,
 | |
|       };
 | |
|     });
 | |
| 
 | |
|     teardown(() => { sandbox.restore(); });
 | |
| 
 | |
|     test('dialog opens fetch and set previews', done => {
 | |
|       sandbox.stub(element.$.restAPI, 'getRobotCommentFixPreview')
 | |
|           .returns(Promise.resolve({
 | |
|             f1: {
 | |
|               meta_a: {},
 | |
|               meta_b: {},
 | |
|               content: [
 | |
|                 {
 | |
|                   ab: ['loqlwkqll'],
 | |
|                 },
 | |
|                 {
 | |
|                   b: ['qwqqsqw'],
 | |
|                 },
 | |
|                 {
 | |
|                   ab: ['qwqqsqw', 'qweqeqweqeq', 'qweqweq'],
 | |
|                 },
 | |
|               ],
 | |
|             },
 | |
|             f2: {
 | |
|               meta_a: {},
 | |
|               meta_b: {},
 | |
|               content: [
 | |
|                 {
 | |
|                   ab: ['eqweqweqwex'],
 | |
|                 },
 | |
|                 {
 | |
|                   b: ['zassdasd'],
 | |
|                 },
 | |
|                 {
 | |
|                   ab: ['zassdasd', 'dasdasda', 'asdasdad'],
 | |
|                 },
 | |
|               ],
 | |
|             },
 | |
|           }));
 | |
|       sandbox.stub(element.$.applyFixOverlay, 'open').returns(Promise.resolve());
 | |
| 
 | |
|       element.open({detail: {patchNum: 2, comment: ROBOT_COMMENT}})
 | |
|           .then(() => {
 | |
|             assert.equal(element._currentFix.fix_id, 'fix_1');
 | |
|             assert.equal(element._currentPreviews.length, 2);
 | |
|             assert.equal(element._robotId, 'robot_1');
 | |
|             done();
 | |
|           });
 | |
|     });
 | |
| 
 | |
|     test('preview endpoint throws error should reset dialog', done => {
 | |
|       element.addEventListener('show-error', () => {
 | |
|         assert.deepEqual(element._currentFix, {});
 | |
|         assert.equal(element._currentPreviews.length, 0);
 | |
|         done();
 | |
|       });
 | |
|       sandbox.stub(element.$.restAPI, 'getRobotCommentFixPreview',
 | |
|           () => Promise.reject(new Error('backend error')));
 | |
| 
 | |
|       element.open({detail: {patchNum: 2, comment: ROBOT_COMMENT}});
 | |
|     });
 | |
| 
 | |
|     test('apply fix button should call apply' +
 | |
|     'and navigate to change view', done => {
 | |
|       sandbox.stub(element.$.restAPI, 'applyFixSuggestion')
 | |
|           .returns(Promise.resolve());
 | |
|       sandbox.stub(Gerrit.Nav, 'navigateToChange');
 | |
|       element._currentFix = {fix_id: '123'};
 | |
| 
 | |
|       element._handleApplyFix().then(() => {
 | |
|         assert.isTrue(element.$.restAPI.applyFixSuggestion
 | |
|             .calledWithExactly('1', 2, '123'));
 | |
|         assert.isTrue(Gerrit.Nav.navigateToChange.calledWithExactly({
 | |
|           _number: '1',
 | |
|           project: 'project',
 | |
|         }, 'edit', 2));
 | |
| 
 | |
|         // reset gr-apply-fix-dialog and close
 | |
|         assert.deepEqual(element._currentFix, {});
 | |
|         assert.equal(element._currentPreviews.length, 0);
 | |
|         done();
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| </script>
 |