gitlab-org--gitlab-foss/spec/frontend/runner/components/runner_type_tabs_spec.js

203 lines
4.6 KiB
JavaScript

import { GlTab } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils';
import RunnerTypeTabs from '~/runner/components/runner_type_tabs.vue';
import RunnerCount from '~/runner/components/stat/runner_count.vue';
import { INSTANCE_TYPE, GROUP_TYPE, PROJECT_TYPE } from '~/runner/constants';
const mockSearch = { runnerType: null, filters: [], pagination: { page: 1 }, sort: 'CREATED_DESC' };
const mockCount = (type, multiplier = 1) => {
let count;
switch (type) {
case INSTANCE_TYPE:
count = 3;
break;
case GROUP_TYPE:
count = 2;
break;
case PROJECT_TYPE:
count = 1;
break;
default:
count = 6;
break;
}
return count * multiplier;
};
describe('RunnerTypeTabs', () => {
let wrapper;
const findTabs = () => wrapper.findAllComponents(GlTab);
const findActiveTab = () =>
findTabs()
.filter((tab) => tab.attributes('active') === 'true')
.at(0);
const getTabsTitles = () => findTabs().wrappers.map((tab) => tab.text().replace(/\s+/g, ' '));
const createComponent = ({ props, stubs, ...options } = {}) => {
wrapper = shallowMount(RunnerTypeTabs, {
propsData: {
value: mockSearch,
countScope: INSTANCE_TYPE,
countVariables: {},
...props,
},
stubs: {
GlTab,
...stubs,
},
...options,
});
};
afterEach(() => {
wrapper.destroy();
});
it('Renders all options to filter runners by default', () => {
createComponent();
expect(getTabsTitles()).toEqual(['All', 'Instance', 'Group', 'Project']);
});
it('Shows count when receiving a number', () => {
createComponent({
stubs: {
RunnerCount: {
props: ['variables'],
render() {
return this.$scopedSlots.default({
count: mockCount(this.variables.type),
});
},
},
},
});
expect(getTabsTitles()).toEqual([`All 6`, `Instance 3`, `Group 2`, `Project 1`]);
});
it('Shows formatted count when receiving a large number', () => {
createComponent({
stubs: {
RunnerCount: {
props: ['variables'],
render() {
return this.$scopedSlots.default({
count: mockCount(this.variables.type, 1000),
});
},
},
},
});
expect(getTabsTitles()).toEqual([
`All 6,000`,
`Instance 3,000`,
`Group 2,000`,
`Project 1,000`,
]);
});
it('Renders a count next to each tab', () => {
const mockVariables = {
paused: true,
status: 'ONLINE',
};
createComponent({
props: {
countVariables: mockVariables,
},
});
findTabs().wrappers.forEach((tab) => {
expect(tab.findComponent(RunnerCount).props()).toEqual({
scope: INSTANCE_TYPE,
skip: false,
variables: expect.objectContaining(mockVariables),
});
});
});
it('Renders fewer options to filter runners', () => {
createComponent({
props: {
runnerTypes: [GROUP_TYPE, PROJECT_TYPE],
},
});
expect(getTabsTitles()).toEqual(['All', 'Group', 'Project']);
});
it('"All" is selected by default', () => {
createComponent();
expect(findActiveTab().text()).toBe('All');
});
it('Another tab can be preselected by the user', () => {
createComponent({
props: {
value: {
...mockSearch,
runnerType: INSTANCE_TYPE,
},
},
});
expect(findActiveTab().text()).toBe('Instance');
});
describe('When the user selects a tab', () => {
const emittedValue = () => wrapper.emitted('input')[0][0];
beforeEach(() => {
createComponent();
findTabs().at(2).vm.$emit('click');
});
it(`Runner type is emitted`, () => {
expect(emittedValue()).toEqual({
...mockSearch,
runnerType: GROUP_TYPE,
});
});
it('Runner type is selected', async () => {
const newValue = emittedValue();
await wrapper.setProps({ value: newValue });
expect(findActiveTab().text()).toBe('Group');
});
});
describe('Component API', () => {
describe('When .refetch() is called', () => {
let mockRefetch;
beforeEach(() => {
mockRefetch = jest.fn();
createComponent({
stubs: {
RunnerCount: {
methods: {
refetch: mockRefetch,
},
render() {},
},
},
});
wrapper.vm.refetch();
});
it('refetch is called for each count', () => {
expect(mockRefetch).toHaveBeenCalledTimes(4);
});
});
});
});