2018-09-25 16:28:26 +00:00
|
|
|
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';
|
2018-07-19 01:59:04 +00:00
|
|
|
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);
|
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
const controlGroupService = Service.extend({
|
2018-07-19 01:59:04 +00:00
|
|
|
deleteControlGroupToken: sinon.stub(),
|
|
|
|
markTokenForUnwrap: sinon.stub(),
|
|
|
|
});
|
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
const routerService = Service.extend({
|
|
|
|
transitionTo: sinon.stub().returns(resolve()),
|
2018-07-19 01:59:04 +00:00
|
|
|
});
|
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
const storeService = Service.extend({
|
2018-07-19 01:59:04 +00:00
|
|
|
adapterFor() {
|
|
|
|
return {
|
|
|
|
toolAction() {
|
2018-09-25 16:28:26 +00:00
|
|
|
return resolve({ data: { foo: 'bar' } });
|
2018-07-19 01:59:04 +00:00
|
|
|
},
|
|
|
|
};
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
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');
|
|
|
|
});
|
|
|
|
});
|
2018-07-19 01:59:04 +00:00
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
const MODEL = {
|
|
|
|
approved: false,
|
|
|
|
requestPath: 'foo/bar',
|
|
|
|
id: 'accessor',
|
|
|
|
requestEntity: { id: 'requestor', name: 'entity8509' },
|
|
|
|
reload: sinon.stub(),
|
2018-07-19 01:59:04 +00:00
|
|
|
};
|
2018-09-25 16:28:26 +00:00
|
|
|
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');
|
|
|
|
});
|
2018-07-19 01:59:04 +00:00
|
|
|
});
|
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
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');
|
|
|
|
});
|
2018-07-19 01:59:04 +00:00
|
|
|
});
|
|
|
|
});
|