mirror of
https://github.com/kemko/nomad.git
synced 2026-01-03 08:55:43 +03:00
64 lines
1.8 KiB
JavaScript
64 lines
1.8 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import { module, test } from 'qunit';
|
|
import { setupRenderingTest } from 'ember-qunit';
|
|
import { click, render } from '@ember/test-helpers';
|
|
import hbs from 'htmlbars-inline-precompile';
|
|
import { componentA11yAudit } from 'nomad-ui/tests/helpers/a11y-audit';
|
|
|
|
import sinon from 'sinon';
|
|
|
|
import {
|
|
triggerCopyError,
|
|
triggerCopySuccess,
|
|
} from 'ember-cli-clipboard/test-support';
|
|
|
|
module('Integration | Component | copy-button', function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
test('it shows the copy icon by default', async function (assert) {
|
|
assert.expect(2);
|
|
|
|
await render(hbs`<CopyButton />`);
|
|
|
|
assert.dom('.copy-button .icon-is-copy-action').exists();
|
|
await componentA11yAudit(this.element, assert);
|
|
});
|
|
|
|
test('it shows the success icon on success and resets afterward', async function (assert) {
|
|
assert.expect(4);
|
|
|
|
const clock = sinon.useFakeTimers({ shouldAdvanceTime: true });
|
|
|
|
await render(hbs`<CopyButton @clipboardText="tomster" />`);
|
|
|
|
await click('.copy-button button');
|
|
await triggerCopySuccess('.copy-button button');
|
|
|
|
assert.dom('[data-test-copy-success]').exists();
|
|
await componentA11yAudit(this.element, assert);
|
|
|
|
clock.runAll();
|
|
|
|
assert.dom('[data-test-copy-success]').doesNotExist();
|
|
assert.dom('.copy-button .icon-is-copy-action').exists();
|
|
|
|
clock.restore();
|
|
});
|
|
|
|
test('it shows the error icon on error', async function (assert) {
|
|
assert.expect(2);
|
|
|
|
await render(hbs`<CopyButton @clipboardText="tomster" />`);
|
|
|
|
await click('.copy-button button');
|
|
await triggerCopyError('.copy-button button');
|
|
|
|
assert.dom('.copy-button .icon-is-alert-triangle').exists();
|
|
await componentA11yAudit(this.element, assert);
|
|
});
|
|
});
|