datahub/datahub-web/@datahub/utils/tests/integration/components/concurrency-task-state-handler-test.ts
Charlie Tran 843a6c5bbb
feat(frontend): update datahub-web client UI code (#1806)
* Releases updated version of datahub-web client UI code

* Fix typo in yarn lock

* Change yarn lock to match yarn registry directories

* Previous commit missed some paths

* Even more changes to yarnlock missing in previous commit

* Include codegen file for typings

* Add files to get parity for datahub-web and current OS datahub-midtier

* Add in typo fix from previous commit - change to proper license

* Implement proper OS fix for person entity picture url

* Workarounds for open source DH issues

* Fixes institutional memory api and removes unopensourced tabs for datasets

* Fixes search dataset deprecation and user search issue as a result of changes

* Remove internal only options in the avatar menu
2020-08-26 15:44:50 -07:00

90 lines
2.6 KiB
TypeScript

import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { render } from '@ember/test-helpers';
import hbs from 'htmlbars-inline-precompile';
import { setProperties } from '@ember/object';
import { TestContext } from 'ember-test-helpers';
interface IMockTaskParams {
isRunning?: boolean;
isError?: boolean;
}
interface IMockTask {
isRunning: boolean;
last: {
isError: boolean;
};
}
interface IMyTest extends TestContext {
task: IMockTask;
}
const createMockTask = ({ isRunning = false, isError = false }: IMockTaskParams = {}): IMockTask => ({
isRunning,
last: {
isError
}
});
module('Integration | Component | concurrency-task-state-handler', function(hooks): void {
setupRenderingTest(hooks);
test('should yield when task is done', async function(this: IMyTest, assert) {
const task = createMockTask();
setProperties(this, { task });
await render(hbs`
<ConcurrencyTaskStateHandler @task={{this.task}}>
template block text
</ConcurrencyTaskStateHandler>
`);
assert.equal(this.element.textContent && this.element.textContent.trim(), 'template block text');
});
test('should not yield when task is running', async function(this: IMyTest, assert) {
const task = createMockTask({ isRunning: true });
setProperties(this, { task });
await render(hbs`
<ConcurrencyTaskStateHandler @task={{this.task}}>
template block text
</ConcurrencyTaskStateHandler>
`);
assert.equal(this.element.textContent && this.element.textContent.trim(), '');
});
test('should show error', async function(this: IMyTest, assert) {
const task = createMockTask({ isError: true });
setProperties(this, { task });
await render(hbs`
<ConcurrencyTaskStateHandler @task={{this.task}}>
template block text
</ConcurrencyTaskStateHandler>
`);
const subHead = this.element.querySelector('.empty-state__header');
assert.equal(
subHead && subHead.textContent && subHead.textContent.trim(),
'An error occurred. Please try again shortly.'
);
});
test('should show custom error', async function(this: IMyTest, assert) {
const task = createMockTask({ isError: true });
setProperties(this, { task });
await render(hbs`
<ConcurrencyTaskStateHandler @task={{this.task}} @errorHeading="Custom Error">
template block text
</ConcurrencyTaskStateHandler>
`);
const subHead = this.element.querySelector('.empty-state__header');
assert.equal(subHead && subHead.textContent && subHead.textContent.trim(), 'Custom Error');
});
});