757afb4de9
* add no-jquery rule and move event listeners to ember-concurrency tasks * remove unnecessary onchange and handleKeyDown actions * add element.closest polyfill and convert linked-block to use native dom apis * update pretender, fetch, page-object, add optional-features, remove ember/jquery * turn off jquery inclusion * remove jQuery.isPlainObject usage * violatedDirective isn't always formatted the same * use fetch and the ember-fetch adapter mixin * move to fetch and lowercase headers for pretender * display non-ember-data errors * use new async fn test style and lowercase headers in auth service test * setContext is not necessary with the new style tests and ember-cli-page-object - it actually triggers jquery usage * update ember-fetch, ember-cli-pretender * wait for permissions check * lowercase header name in auth test * refactor transit tests to one test per key type * simplify pollCluster helper * stop flakey tests by prefering the native fetch * avoid uncaught TransitionAborted error by navigating directly to unseal * unset model on controller after unloading it because controllers are singletons * update yarn.lock
83 lines
2.6 KiB
JavaScript
83 lines
2.6 KiB
JavaScript
import { later, run } from '@ember/runloop';
|
|
import { resolve } from 'rsvp';
|
|
import Service from '@ember/service';
|
|
import { module, test } from 'qunit';
|
|
import { setupRenderingTest } from 'ember-qunit';
|
|
import { render, settled } from '@ember/test-helpers';
|
|
import hbs from 'htmlbars-inline-precompile';
|
|
import sinon from 'sinon';
|
|
import { create } from 'ember-cli-page-object';
|
|
import controlGroupSuccess from '../../pages/components/control-group-success';
|
|
|
|
const component = create(controlGroupSuccess);
|
|
|
|
const controlGroupService = Service.extend({
|
|
deleteControlGroupToken: sinon.stub(),
|
|
markTokenForUnwrap: sinon.stub(),
|
|
});
|
|
|
|
const routerService = Service.extend({
|
|
transitionTo: sinon.stub().returns(resolve()),
|
|
});
|
|
|
|
const storeService = Service.extend({
|
|
adapterFor() {
|
|
return {
|
|
toolAction() {
|
|
return resolve({ data: { foo: 'bar' } });
|
|
},
|
|
};
|
|
},
|
|
});
|
|
|
|
module('Integration | Component | control group success', function(hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
hooks.beforeEach(function() {
|
|
run(() => {
|
|
this.owner.unregister('service:store');
|
|
this.owner.register('service:control-group', controlGroupService);
|
|
this.controlGroup = this.owner.lookup('service:control-group');
|
|
this.owner.register('service:router', routerService);
|
|
this.owner.register('service:store', storeService);
|
|
this.router = this.owner.lookup('service:router');
|
|
});
|
|
});
|
|
|
|
const MODEL = {
|
|
approved: false,
|
|
requestPath: 'foo/bar',
|
|
id: 'accessor',
|
|
requestEntity: { id: 'requestor', name: 'entity8509' },
|
|
reload: sinon.stub(),
|
|
};
|
|
test('render with saved token', async function(assert) {
|
|
let response = {
|
|
uiParams: { url: '/foo' },
|
|
token: 'token',
|
|
};
|
|
this.set('model', MODEL);
|
|
this.set('response', response);
|
|
await render(hbs`{{control-group-success model=model controlGroupResponse=response }}`);
|
|
assert.ok(component.showsNavigateMessage, 'shows unwrap message');
|
|
await component.navigate();
|
|
later(() => run.cancelTimers(), 50);
|
|
return settled().then(() => {
|
|
assert.ok(this.controlGroup.markTokenForUnwrap.calledOnce, 'marks token for unwrap');
|
|
assert.ok(this.router.transitionTo.calledOnce, 'calls router transition');
|
|
});
|
|
});
|
|
|
|
test('render without token', async function(assert) {
|
|
this.set('model', MODEL);
|
|
await render(hbs`{{control-group-success model=model}}`);
|
|
assert.ok(component.showsUnwrapForm, 'shows unwrap form');
|
|
await component.token('token');
|
|
component.unwrap();
|
|
later(() => run.cancelTimers(), 50);
|
|
return settled().then(() => {
|
|
assert.ok(component.showsJsonViewer, 'shows unwrapped data');
|
|
});
|
|
});
|
|
});
|