mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-10-31 02:28:09 +00:00 
			
		
		
		
	 7c14aa6e00
			
		
	
	7c14aa6e00
	
	
	
		
			
			* Show JSON editor by default if secret data is complex, but do not disable JSON toggle * Add text object warning to kv object editor * a11y fix: do not disable show diff toggle * test and language cleanup * update language * Update tests for expected behavior * language! * Add changelog
		
			
				
	
	
		
			134 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * Copyright (c) HashiCorp, Inc.
 | |
|  * SPDX-License-Identifier: BUSL-1.1
 | |
|  */
 | |
| 
 | |
| import { module, test } from 'qunit';
 | |
| import { setupRenderingTest } from 'ember-qunit';
 | |
| import { create } from 'ember-cli-page-object';
 | |
| import { render, fillIn, find, waitUntil, click } from '@ember/test-helpers';
 | |
| import hbs from 'htmlbars-inline-precompile';
 | |
| import jsonEditor from '../../pages/components/json-editor';
 | |
| import sinon from 'sinon';
 | |
| import { setRunOptions } from 'ember-a11y-testing/test-support';
 | |
| 
 | |
| const component = create(jsonEditor);
 | |
| 
 | |
| module('Integration | Component | json-editor', function (hooks) {
 | |
|   setupRenderingTest(hooks);
 | |
| 
 | |
|   const JSON_BLOB = `{
 | |
|     "test": "test"
 | |
|   }`;
 | |
|   const BAD_JSON_BLOB = `{
 | |
|     "test": test
 | |
|   }`;
 | |
| 
 | |
|   hooks.beforeEach(function () {
 | |
|     this.set('valueUpdated', sinon.spy());
 | |
|     this.set('onFocusOut', sinon.spy());
 | |
|     this.set('json_blob', JSON_BLOB);
 | |
|     this.set('bad_json_blob', BAD_JSON_BLOB);
 | |
|     this.set('hashi-read-only-theme', 'hashi-read-only auto-height');
 | |
|     setRunOptions({
 | |
|       rules: {
 | |
|         // CodeMirror has a secret textarea without a label that causes this problem
 | |
|         label: { enabled: false },
 | |
|         // TODO: investigate and fix Codemirror styling
 | |
|         'color-contrast': { enabled: false },
 | |
|       },
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   test('it renders', async function (assert) {
 | |
|     await render(hbs`<JsonEditor
 | |
|         @value={{"{}"}}
 | |
|         @title={{"Test title"}}
 | |
|         @showToolbar={{true}}
 | |
|         @readOnly={{true}}
 | |
|       />`);
 | |
| 
 | |
|     assert.strictEqual(component.title, 'Test title', 'renders the provided title');
 | |
|     assert.true(component.hasToolbar, 'renders the toolbar');
 | |
|     assert.true(component.hasCopyButton, 'renders the copy button');
 | |
|     assert.true(component.hasJSONEditor, 'renders the code mirror modifier');
 | |
|     assert.ok(component.canEdit, 'json editor can be edited');
 | |
|   });
 | |
| 
 | |
|   test('it handles editing and linting and styles to json', async function (assert) {
 | |
|     await render(hbs`<JsonEditor
 | |
|       @value={{this.json_blob}}
 | |
|       @readOnly={{false}}
 | |
|       @valueUpdated={{this.valueUpdated}}
 | |
|       @onFocusOut={{this.onFocusOut}}
 | |
|     />`);
 | |
|     // check for json styling
 | |
|     assert.dom('.cm-property').hasStyle({
 | |
|       color: 'rgb(158, 132, 197)',
 | |
|     });
 | |
|     assert.dom('.cm-string:nth-child(2)').hasStyle({
 | |
|       color: 'rgb(29, 219, 163)',
 | |
|     });
 | |
| 
 | |
|     await fillIn('textarea', this.bad_json_blob);
 | |
|     await waitUntil(() => find('.CodeMirror-lint-marker-error'));
 | |
|     assert.dom('.CodeMirror-lint-marker-error').exists('throws linting error');
 | |
|     assert.dom('.CodeMirror-linenumber').exists('shows line numbers');
 | |
|   });
 | |
| 
 | |
|   test('it renders the correct theme and expected styling', async function (assert) {
 | |
|     await render(hbs`<JsonEditor
 | |
|       @value={{this.json_blob}}
 | |
|       @theme={{this.hashi-read-only-theme}}
 | |
|       @readOnly={{true}}
 | |
|     />`);
 | |
|     assert.dom('.cm-s-hashi-read-only').hasStyle({
 | |
|       background: 'rgb(247, 248, 250) none repeat scroll 0% 0% / auto padding-box border-box',
 | |
|     });
 | |
|     assert.dom('.CodeMirror-linenumber').doesNotExist('on readOnly does not show line numbers');
 | |
|   });
 | |
| 
 | |
|   test('it should render example and restore it', async function (assert) {
 | |
|     this.value = null;
 | |
|     this.example = 'this is a test example';
 | |
| 
 | |
|     await render(hbs`
 | |
|       <JsonEditor
 | |
|         @value={{this.value}}
 | |
|         @example={{this.example}}
 | |
|         @mode="ruby"
 | |
|         @valueUpdated={{fn (mut this.value)}}
 | |
|       />
 | |
|     `);
 | |
| 
 | |
|     assert.dom('.CodeMirror-code').hasText(`1${this.example}`, 'Example renders when there is no value');
 | |
|     assert.dom('[data-test-restore-example]').isDisabled('Restore button disabled when showing example');
 | |
|     await fillIn('textarea', '');
 | |
|     await fillIn('textarea', 'adding a value should allow the example to be restored');
 | |
|     await click('[data-test-restore-example]');
 | |
|     assert.dom('.CodeMirror-code').hasText(`1${this.example}`, 'Example is restored');
 | |
|     assert.strictEqual(this.value, null, 'Value is cleared on restore example');
 | |
|   });
 | |
| 
 | |
|   test('obscure option works correctly', async function (assert) {
 | |
|     this.set('readOnly', true);
 | |
|     await render(hbs`<JsonEditor
 | |
|       @value={{this.json_blob}}
 | |
|       @allowObscure={{true}}
 | |
|       @readOnly={{this.readOnly}}
 | |
|       @valueUpdated={{this.valueUpdated}}
 | |
|       @onFocusOut={{this.onFocusOut}}
 | |
|     />`);
 | |
|     assert.dom('.CodeMirror-code').hasText(`{ "test": "********"}`, 'shows data with obscured values');
 | |
|     assert.dom('[data-test-toggle-input="revealValues"]').isNotChecked('reveal values toggle is unchecked');
 | |
|     await click('[data-test-toggle-input="revealValues"]');
 | |
|     assert.dom('.CodeMirror-code').hasText(JSON_BLOB, 'shows data with real values');
 | |
|     assert.dom('[data-test-toggle-input="revealValues"]').isChecked('reveal values toggle is checked');
 | |
|     // turn obscure back on to ensure readonly overrides reveal setting
 | |
|     await click('[data-test-toggle-input="revealValues"]');
 | |
|     this.set('readOnly', false);
 | |
|     assert.dom('[data-test-toggle-input="revealValues"]').doesNotExist('reveal values toggle is hidden');
 | |
|     assert.dom('.CodeMirror-code').hasText(JSON_BLOB, 'shows data with real values on edit mode');
 | |
|   });
 | |
| });
 |