
Include an empty file - this will be filled with Polymer 2 specific code later, and it's useful to have the empty file now because the Polymer 2 change will likely be pending very long, and we would like to avoid conflicts keeping so many files in a pending change for long. Also include a harmless polyfill that we need for Polymer 2. Change-Id: I504e52ae937edff1d35b29700882b522ef4dbc64
179 lines
5.6 KiB
HTML
179 lines
5.6 KiB
HTML
<!DOCTYPE html>
|
|
<!--
|
|
@license
|
|
Copyright (C) 2018 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-repo-plugin-config</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-repo-plugin-config.html">
|
|
|
|
<script>void(0);</script>
|
|
|
|
<test-fixture id="basic">
|
|
<template>
|
|
<gr-repo-plugin-config></gr-repo-plugin-config>
|
|
</template>
|
|
</test-fixture>
|
|
|
|
<script>
|
|
suite('gr-repo-plugin-config tests', () => {
|
|
let element;
|
|
let sandbox;
|
|
|
|
setup(() => {
|
|
sandbox = sinon.sandbox.create();
|
|
element = fixture('basic');
|
|
});
|
|
|
|
teardown(() => sandbox.restore());
|
|
|
|
test('_computePluginConfigOptions', () => {
|
|
assert.deepEqual(element._computePluginConfigOptions(), []);
|
|
assert.deepEqual(element._computePluginConfigOptions({}), []);
|
|
assert.deepEqual(element._computePluginConfigOptions({base: {}}), []);
|
|
assert.deepEqual(element._computePluginConfigOptions(
|
|
{base: {config: {}}}), []);
|
|
assert.deepEqual(element._computePluginConfigOptions(
|
|
{base: {config: {testKey: 'testInfo'}}}),
|
|
[{_key: 'testKey', info: 'testInfo'}]);
|
|
});
|
|
|
|
test('_computeDisabled', () => {
|
|
assert.isFalse(element._computeDisabled('true'));
|
|
assert.isTrue(element._computeDisabled('false'));
|
|
});
|
|
|
|
test('_handleChange', () => {
|
|
const eventStub = sandbox.stub(element, 'dispatchEvent');
|
|
element.pluginData = {
|
|
name: 'testName',
|
|
config: {plugin: {value: 'test'}},
|
|
};
|
|
element._handleChange({
|
|
_key: 'plugin',
|
|
info: {value: 'newTest'},
|
|
notifyPath: 'plugin.value',
|
|
});
|
|
|
|
assert.isTrue(eventStub.called);
|
|
|
|
const {detail} = eventStub.lastCall.args[0];
|
|
assert.equal(detail.name, 'testName');
|
|
assert.deepEqual(detail.config, {plugin: {value: 'newTest'}});
|
|
assert.equal(detail.notifyPath, 'testName.plugin.value');
|
|
});
|
|
|
|
suite('option types', () => {
|
|
let changeStub;
|
|
let buildStub;
|
|
|
|
setup(() => {
|
|
changeStub = sandbox.stub(element, '_handleChange');
|
|
buildStub = sandbox.stub(element, '_buildConfigChangeInfo');
|
|
});
|
|
|
|
test('ARRAY type option', () => {
|
|
element.pluginData = {
|
|
name: 'testName',
|
|
config: {plugin: {value: 'test', type: 'ARRAY'}},
|
|
};
|
|
flushAsynchronousOperations();
|
|
|
|
const editor = element.$$('gr-plugin-config-array-editor');
|
|
assert.ok(editor);
|
|
element._handleArrayChange({detail: 'test'});
|
|
assert.isTrue(changeStub.called);
|
|
assert.equal(changeStub.lastCall.args[0], 'test');
|
|
});
|
|
|
|
test('BOOLEAN type option', () => {
|
|
element.pluginData = {
|
|
name: 'testName',
|
|
config: {plugin: {value: 'true', type: 'BOOLEAN'}},
|
|
};
|
|
flushAsynchronousOperations();
|
|
|
|
const toggle = element.$$('paper-toggle-button');
|
|
assert.ok(toggle);
|
|
toggle.click();
|
|
flushAsynchronousOperations();
|
|
|
|
assert.isTrue(buildStub.called);
|
|
assert.deepEqual(buildStub.lastCall.args, ['false', 'plugin']);
|
|
|
|
assert.isTrue(changeStub.called);
|
|
});
|
|
|
|
test('INT/LONG/STRING type option', () => {
|
|
element.pluginData = {
|
|
name: 'testName',
|
|
config: {plugin: {value: 'test', type: 'STRING'}},
|
|
};
|
|
flushAsynchronousOperations();
|
|
|
|
const input = element.$$('input');
|
|
assert.ok(input);
|
|
input.value = 'newTest';
|
|
input.dispatchEvent(new Event('input'));
|
|
flushAsynchronousOperations();
|
|
|
|
assert.isTrue(buildStub.called);
|
|
assert.deepEqual(buildStub.lastCall.args, ['newTest', 'plugin']);
|
|
|
|
assert.isTrue(changeStub.called);
|
|
});
|
|
|
|
test('LIST type option', () => {
|
|
const permitted_values = ['test', 'newTest'];
|
|
element.pluginData = {
|
|
name: 'testName',
|
|
config: {plugin: {value: 'test', type: 'LIST', permitted_values}},
|
|
};
|
|
flushAsynchronousOperations();
|
|
|
|
const select = element.$$('select');
|
|
assert.ok(select);
|
|
select.value = 'newTest';
|
|
select.dispatchEvent(new Event(
|
|
'change', {bubbles: true, composed: true}));
|
|
flushAsynchronousOperations();
|
|
|
|
assert.isTrue(buildStub.called);
|
|
assert.deepEqual(buildStub.lastCall.args, ['newTest', 'plugin']);
|
|
|
|
assert.isTrue(changeStub.called);
|
|
});
|
|
});
|
|
|
|
test('_buildConfigChangeInfo', () => {
|
|
element.pluginData = {
|
|
name: 'testName',
|
|
config: {plugin: {value: 'test'}},
|
|
};
|
|
const detail = element._buildConfigChangeInfo('newTest', 'plugin');
|
|
assert.equal(detail._key, 'plugin');
|
|
assert.deepEqual(detail.info, {value: 'newTest'});
|
|
assert.equal(detail.notifyPath, 'plugin.value');
|
|
});
|
|
});
|
|
</script>
|