debian-mirror-gitlab/spec/javascripts/deploy_keys/components/action_btn_spec.js

73 lines
1.5 KiB
JavaScript
Raw Normal View History

2017-08-17 22:00:37 +05:30
import Vue from 'vue';
import eventHub from '~/deploy_keys/eventhub';
import actionBtn from '~/deploy_keys/components/action_btn.vue';
describe('Deploy keys action btn', () => {
const data = getJSONFixture('deploy_keys/keys.json');
const deployKey = data.enabled_keys[0];
let vm;
2018-10-15 14:42:47 +05:30
beforeEach(done => {
const ActionBtnComponent = Vue.extend({
components: {
actionBtn,
},
data() {
return {
deployKey,
};
2017-08-17 22:00:37 +05:30
},
2018-10-15 14:42:47 +05:30
template: `
<action-btn
:deploy-key="deployKey"
type="enable">
Enable
</action-btn>`,
});
vm = new ActionBtnComponent().$mount();
2017-08-17 22:00:37 +05:30
2018-10-15 14:42:47 +05:30
Vue.nextTick()
.then(done)
.catch(done.fail);
2017-08-17 22:00:37 +05:30
});
2018-10-15 14:42:47 +05:30
it('renders the default slot', () => {
expect(vm.$el.textContent.trim()).toBe('Enable');
2017-08-17 22:00:37 +05:30
});
2018-10-15 14:42:47 +05:30
it('sends eventHub event with btn type', done => {
2017-08-17 22:00:37 +05:30
spyOn(eventHub, '$emit');
vm.$el.click();
2018-10-15 14:42:47 +05:30
Vue.nextTick(() => {
expect(eventHub.$emit).toHaveBeenCalledWith('enable.key', deployKey, jasmine.anything());
2017-08-17 22:00:37 +05:30
done();
});
});
2018-10-15 14:42:47 +05:30
it('shows loading spinner after click', done => {
2017-08-17 22:00:37 +05:30
vm.$el.click();
2018-10-15 14:42:47 +05:30
Vue.nextTick(() => {
expect(vm.$el.querySelector('.fa')).toBeDefined();
2017-08-17 22:00:37 +05:30
done();
});
});
2018-10-15 14:42:47 +05:30
it('disables button after click', done => {
2017-08-17 22:00:37 +05:30
vm.$el.click();
2018-10-15 14:42:47 +05:30
Vue.nextTick(() => {
expect(vm.$el.classList.contains('disabled')).toBeTruthy();
2017-08-17 22:00:37 +05:30
2018-10-15 14:42:47 +05:30
expect(vm.$el.getAttribute('disabled')).toBe('disabled');
2017-08-17 22:00:37 +05:30
done();
});
});
});