2018-05-24 03:10:21 +00:00
|
|
|
import { moduleForComponent, test } from 'ember-qunit';
|
|
|
|
import hbs from 'htmlbars-inline-precompile';
|
|
|
|
import sinon from 'sinon';
|
|
|
|
import { create } from 'ember-cli-page-object';
|
|
|
|
import itemDetails from 'vault/tests/pages/components/identity/item-details';
|
|
|
|
import Ember from 'ember';
|
|
|
|
|
|
|
|
const component = create(itemDetails);
|
|
|
|
const { getOwner } = Ember;
|
|
|
|
|
|
|
|
moduleForComponent('identity/item-details', 'Integration | Component | identity/item details', {
|
|
|
|
integration: true,
|
|
|
|
beforeEach() {
|
|
|
|
component.setContext(this);
|
|
|
|
getOwner(this).lookup('service:flash-messages').registerTypes(['success']);
|
|
|
|
},
|
|
|
|
afterEach() {
|
|
|
|
component.removeContext();
|
2018-05-29 14:14:31 +00:00
|
|
|
},
|
2018-05-24 03:10:21 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test('it renders the disabled warning', function(assert) {
|
|
|
|
let model = Ember.Object.create({
|
|
|
|
save() {
|
|
|
|
return Ember.RSVP.resolve();
|
|
|
|
},
|
|
|
|
disabled: true,
|
2018-05-29 14:14:31 +00:00
|
|
|
canEdit: true,
|
2018-05-24 03:10:21 +00:00
|
|
|
});
|
|
|
|
sinon.spy(model, 'save');
|
|
|
|
this.set('model', model);
|
|
|
|
this.render(hbs`{{identity/item-details model=model}}`);
|
|
|
|
assert.dom('[data-test-disabled-warning]').exists();
|
|
|
|
component.enable();
|
|
|
|
|
|
|
|
assert.ok(model.save.calledOnce, 'clicking enable calls model save');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it does not render the button if canEdit is false', function(assert) {
|
|
|
|
let model = Ember.Object.create({
|
2018-05-29 14:14:31 +00:00
|
|
|
disabled: true,
|
2018-05-24 03:10:21 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
this.set('model', model);
|
|
|
|
this.render(hbs`{{identity/item-details model=model}}`);
|
|
|
|
assert.dom('[data-test-disabled-warning]').exists('shows the warning banner');
|
|
|
|
assert.dom('[data-test-enable]').doesNotExist('does not show the enable button');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it does not render the banner when item is enabled', function(assert) {
|
|
|
|
let model = Ember.Object.create();
|
|
|
|
this.set('model', model);
|
|
|
|
|
|
|
|
this.render(hbs`{{identity/item-details model=model}}`);
|
|
|
|
assert.dom('[data-test-disabled-warning]').doesNotExist('does not show the warning banner');
|
|
|
|
});
|