blob: 0659874c697733a68c1f2741b968a8ed7a43eb30 [file] [log] [blame]
/**
* @license
* Copyright 2018 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import {ConfigParameterInfoType} from '../../../constants/constants.js';
import '../../../test/common-test-setup-karma';
import './gr-plugin-config-array-editor';
import {GrPluginConfigArrayEditor} from './gr-plugin-config-array-editor';
import * as MockInteractions from '@polymer/iron-test-helpers/mock-interactions';
import {queryAll, queryAndAssert} from '../../../test/test-utils.js';
import {GrButton} from '../../shared/gr-button/gr-button.js';
import {fixture, html} from '@open-wc/testing-helpers';
suite('gr-plugin-config-array-editor tests', () => {
let element: GrPluginConfigArrayEditor;
let dispatchStub: sinon.SinonStub;
setup(async () => {
element = await fixture<GrPluginConfigArrayEditor>(html`
<gr-plugin-config-array-editor></gr-plugin-config-array-editor>
`);
element.pluginOption = {
_key: 'test-key',
info: {
type: ConfigParameterInfoType.ARRAY,
values: [],
},
};
});
suite('adding', () => {
setup(() => {
dispatchStub = sinon.stub(element, 'dispatchChanged');
});
test('with enter', async () => {
element.newValue = '';
await element.updateComplete;
MockInteractions.pressAndReleaseKeyOn(
queryAndAssert<HTMLInputElement>(element, '#input'),
13
); // Enter
await element.updateComplete;
assert.isFalse(
queryAndAssert<HTMLInputElement>(element, '#input').hasAttribute(
'disabled'
)
);
await element.updateComplete;
assert.isFalse(dispatchStub.called);
element.newValue = 'test';
await element.updateComplete;
MockInteractions.pressAndReleaseKeyOn(
queryAndAssert<HTMLInputElement>(element, '#input'),
13
); // Enter
await element.updateComplete;
assert.isFalse(
queryAndAssert<HTMLInputElement>(element, '#input').hasAttribute(
'disabled'
)
);
await element.updateComplete;
assert.isTrue(dispatchStub.called);
assert.equal(dispatchStub.lastCall.args[0], 'test');
assert.equal(element.newValue, '');
});
test('with add btn', async () => {
element.newValue = '';
queryAndAssert<GrButton>(element, '#addButton').click();
await element.updateComplete;
assert.isFalse(dispatchStub.called);
element.newValue = 'test';
await element.updateComplete;
queryAndAssert<GrButton>(element, '#addButton').click();
await element.updateComplete;
assert.isTrue(dispatchStub.called);
assert.equal(dispatchStub.lastCall.args[0], 'test');
assert.equal(element.newValue, '');
});
});
test('deleting', async () => {
dispatchStub = sinon.stub(element, 'dispatchChanged');
element.pluginOption = {
_key: '',
info: {type: ConfigParameterInfoType.ARRAY, values: ['test', 'test2']},
};
element.disabled = true;
await element.updateComplete;
const rows = queryAll(element, '.existingItems .row');
assert.equal(rows.length, 2);
const button = queryAndAssert<GrButton>(rows[0], 'gr-button');
MockInteractions.tap(button);
await element.updateComplete;
assert.isFalse(dispatchStub.called);
element.disabled = false;
await element.updateComplete;
button.click();
await element.updateComplete;
assert.isTrue(dispatchStub.called);
assert.deepEqual(dispatchStub.lastCall.args[0], ['test2']);
});
test('dispatchChanged', () => {
const eventStub = sinon.stub(element, 'dispatchEvent');
element.dispatchChanged(['new-test-value']);
assert.isTrue(eventStub.called);
const {detail} = eventStub.lastCall.args[0] as CustomEvent;
assert.equal(detail._key, 'test-key');
assert.deepEqual(detail.info, {type: 'ARRAY', values: ['new-test-value']});
assert.equal(detail.notifyPath, 'test-key.values');
});
});