61 lines
1.7 KiB
JavaScript
61 lines
1.7 KiB
JavaScript
import { GlLoadingIcon } from '@gitlab/ui';
|
|
import { shallowMount, mount } from '@vue/test-utils';
|
|
import mrStatusIcon from '~/vue_merge_request_widget/components/mr_widget_status_icon.vue';
|
|
|
|
describe('MR widget status icon component', () => {
|
|
let wrapper;
|
|
|
|
const findLoadingIcon = () => wrapper.find(GlLoadingIcon);
|
|
const findDisabledMergeButton = () => wrapper.find('[data-testid="disabled-merge-button"]');
|
|
|
|
const createWrapper = (props, mountFn = shallowMount) => {
|
|
wrapper = mountFn(mrStatusIcon, {
|
|
propsData: {
|
|
...props,
|
|
},
|
|
});
|
|
};
|
|
|
|
afterEach(() => {
|
|
wrapper.destroy();
|
|
});
|
|
|
|
describe('while loading', () => {
|
|
it('renders loading icon', () => {
|
|
createWrapper({ status: 'loading' });
|
|
|
|
expect(findLoadingIcon().exists()).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('with status icon', () => {
|
|
it('renders success status icon', () => {
|
|
createWrapper({ status: 'success' }, mount);
|
|
|
|
expect(wrapper.find('[data-testid="status_success-icon"]').exists()).toBe(true);
|
|
});
|
|
|
|
it('renders failed status icon', () => {
|
|
createWrapper({ status: 'failed' }, mount);
|
|
|
|
expect(wrapper.find('[data-testid="status_failed-icon"]').exists()).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('with disabled button', () => {
|
|
it('renders a disabled button', () => {
|
|
createWrapper({ status: 'failed', showDisabledButton: true });
|
|
|
|
expect(findDisabledMergeButton().exists()).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('without disabled button', () => {
|
|
it('does not render a disabled button', () => {
|
|
createWrapper({ status: 'failed' });
|
|
|
|
expect(findDisabledMergeButton().exists()).toBe(false);
|
|
});
|
|
});
|
|
});
|