2019-03-05 13:33:10 -05:00
|
|
|
import { GlModal } from '@gitlab/ui';
|
2021-02-14 13:09:20 -05:00
|
|
|
import { shallowMount } from '@vue/test-utils';
|
2019-03-05 13:33:10 -05:00
|
|
|
import ConfirmRollbackModal from '~/environments/components/confirm_rollback_modal.vue';
|
|
|
|
import eventHub from '~/environments/event_hub';
|
|
|
|
|
|
|
|
describe('Confirm Rollback Modal Component', () => {
|
|
|
|
let environment;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
environment = {
|
|
|
|
name: 'test',
|
|
|
|
last_deployment: {
|
|
|
|
commit: {
|
|
|
|
short_id: 'abc0123',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
modalId: 'test',
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should show "Rollback" when isLastDeployment is false', () => {
|
|
|
|
const component = shallowMount(ConfirmRollbackModal, {
|
|
|
|
propsData: {
|
|
|
|
environment: {
|
|
|
|
...environment,
|
|
|
|
isLastDeployment: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
const modal = component.find(GlModal);
|
|
|
|
|
|
|
|
expect(modal.attributes('title')).toContain('Rollback');
|
|
|
|
expect(modal.attributes('title')).toContain('test');
|
|
|
|
expect(modal.attributes('ok-title')).toBe('Rollback');
|
|
|
|
expect(modal.text()).toContain('commit abc0123');
|
|
|
|
expect(modal.text()).toContain('Are you sure you want to continue?');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should show "Re-deploy" when isLastDeployment is true', () => {
|
|
|
|
const component = shallowMount(ConfirmRollbackModal, {
|
|
|
|
propsData: {
|
|
|
|
environment: {
|
|
|
|
...environment,
|
|
|
|
isLastDeployment: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
const modal = component.find(GlModal);
|
|
|
|
|
|
|
|
expect(modal.attributes('title')).toContain('Re-deploy');
|
|
|
|
expect(modal.attributes('title')).toContain('test');
|
|
|
|
expect(modal.attributes('ok-title')).toBe('Re-deploy');
|
|
|
|
expect(modal.text()).toContain('commit abc0123');
|
|
|
|
expect(modal.text()).toContain('Are you sure you want to continue?');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should emit the "rollback" event when "ok" is clicked', () => {
|
|
|
|
environment = { ...environment, isLastDeployment: true };
|
|
|
|
const component = shallowMount(ConfirmRollbackModal, {
|
|
|
|
propsData: {
|
|
|
|
environment,
|
|
|
|
},
|
|
|
|
});
|
2019-08-12 15:22:58 -04:00
|
|
|
const eventHubSpy = jest.spyOn(eventHub, '$emit');
|
2019-03-05 13:33:10 -05:00
|
|
|
const modal = component.find(GlModal);
|
|
|
|
modal.vm.$emit('ok');
|
|
|
|
|
|
|
|
expect(eventHubSpy).toHaveBeenCalledWith('rollbackEnvironment', environment);
|
|
|
|
});
|
|
|
|
});
|