blob: bd276608c32935612481c0d3a8ada15e5d5627b4 [file] [log] [blame]
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import '../../../test/common-test-setup';
import './gr-edit-file-controls';
import {GrEditFileControls} from './gr-edit-file-controls';
import {GrEditConstants} from '../gr-edit-constants';
import {queryAndAssert} from '../../../test/test-utils';
import {GrDropdown} from '../../shared/gr-dropdown/gr-dropdown';
import {fixture, html, assert} from '@open-wc/testing';
suite('gr-edit-file-controls tests', () => {
let element: GrEditFileControls;
let fileActionHandler: sinon.SinonStub;
setup(async () => {
element = await fixture(
html`<gr-edit-file-controls></gr-edit-file-controls>`
);
fileActionHandler = sinon.stub();
element.addEventListener('file-action-tap', fileActionHandler);
await element.updateComplete;
});
test('render', () => {
assert.shadowDom.equal(
element,
/* HTML */ `
<gr-dropdown down-arrow="" id="actions" link="" vertical-offset="20">
Actions
</gr-dropdown>
`
);
});
test('open tap emits event', async () => {
const actions = queryAndAssert<GrDropdown>(element, '#actions');
element.filePath = 'foo';
actions.open();
await actions.updateComplete;
const row = queryAndAssert<HTMLSpanElement>(actions, 'li [data-id="open"]');
row.click();
assert.isTrue(fileActionHandler.called);
assert.deepEqual(fileActionHandler.lastCall.args[0].detail, {
action: GrEditConstants.Actions.OPEN.id,
path: 'foo',
});
});
test('delete tap emits event', async () => {
const actions = queryAndAssert<GrDropdown>(element, '#actions');
element.filePath = 'foo';
actions.open();
await actions.updateComplete;
const row = queryAndAssert<HTMLSpanElement>(
actions,
'li [data-id="delete"]'
);
row.click();
assert.isTrue(fileActionHandler.called);
assert.deepEqual(fileActionHandler.lastCall.args[0].detail, {
action: GrEditConstants.Actions.DELETE.id,
path: 'foo',
});
});
test('restore tap emits event', async () => {
const actions = queryAndAssert<GrDropdown>(element, '#actions');
element.filePath = 'foo';
actions.open();
await actions.updateComplete;
const row = queryAndAssert<HTMLSpanElement>(
actions,
'li [data-id="restore"]'
);
row.click();
assert.isTrue(fileActionHandler.called);
assert.deepEqual(fileActionHandler.lastCall.args[0].detail, {
action: GrEditConstants.Actions.RESTORE.id,
path: 'foo',
});
});
test('rename tap emits event', async () => {
const actions = queryAndAssert<GrDropdown>(element, '#actions');
element.filePath = 'foo';
actions.open();
await actions.updateComplete;
const row = queryAndAssert<HTMLSpanElement>(
actions,
'li [data-id="rename"]'
);
row.click();
assert.isTrue(fileActionHandler.called);
assert.deepEqual(fileActionHandler.lastCall.args[0].detail, {
action: GrEditConstants.Actions.RENAME.id,
path: 'foo',
});
});
test('computed properties', () => {
assert.equal(element._allFileActions.length, 4);
});
});