2021-04-29 21:17:54 +05:30
|
|
|
import { createLocalVue, mount, shallowMount } from '@vue/test-utils';
|
|
|
|
import Vue from 'vue';
|
|
|
|
import Vuex from 'vuex';
|
|
|
|
import { extendedWrapper } from 'helpers/vue_test_utils_helper';
|
2019-10-12 21:52:04 +05:30
|
|
|
import Form from '~/jobs/components/manual_variables_form.vue';
|
|
|
|
|
2020-01-01 13:55:28 +05:30
|
|
|
const localVue = createLocalVue();
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
Vue.use(Vuex);
|
|
|
|
|
2019-10-12 21:52:04 +05:30
|
|
|
describe('Manual Variables Form', () => {
|
|
|
|
let wrapper;
|
2021-04-29 21:17:54 +05:30
|
|
|
let store;
|
2020-01-01 13:55:28 +05:30
|
|
|
|
2019-10-12 21:52:04 +05:30
|
|
|
const requiredProps = {
|
|
|
|
action: {
|
|
|
|
path: '/play',
|
|
|
|
method: 'post',
|
|
|
|
button_title: 'Trigger this manual action',
|
|
|
|
},
|
|
|
|
variablesSettingsUrl: '/settings',
|
|
|
|
};
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
const createComponent = ({ props = {}, mountFn = shallowMount } = {}) => {
|
|
|
|
store = new Vuex.Store({
|
|
|
|
actions: {
|
|
|
|
triggerManualJob: jest.fn(),
|
|
|
|
},
|
2019-10-12 21:52:04 +05:30
|
|
|
});
|
2021-04-29 21:17:54 +05:30
|
|
|
|
|
|
|
wrapper = extendedWrapper(
|
|
|
|
mountFn(localVue.extend(Form), {
|
|
|
|
propsData: { ...requiredProps, ...props },
|
|
|
|
localVue,
|
|
|
|
store,
|
|
|
|
}),
|
|
|
|
);
|
2019-10-12 21:52:04 +05:30
|
|
|
};
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
const findInputKey = () => wrapper.findComponent({ ref: 'inputKey' });
|
|
|
|
const findInputValue = () => wrapper.findComponent({ ref: 'inputSecretValue' });
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
const findTriggerBtn = () => wrapper.findByTestId('trigger-manual-job-btn');
|
|
|
|
const findHelpText = () => wrapper.findByTestId('form-help-text');
|
|
|
|
const findDeleteVarBtn = () => wrapper.findByTestId('delete-variable-btn');
|
|
|
|
const findCiVariableKey = () => wrapper.findByTestId('ci-variable-key');
|
|
|
|
const findCiVariableValue = () => wrapper.findByTestId('ci-variable-value');
|
|
|
|
const findAllVariables = () => wrapper.findAllByTestId('ci-variable-row');
|
2020-01-01 13:55:28 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
afterEach(() => {
|
|
|
|
wrapper.destroy();
|
2019-10-12 21:52:04 +05:30
|
|
|
});
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
describe('shallowMount', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
createComponent();
|
|
|
|
});
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
it('renders empty form with correct placeholders', () => {
|
|
|
|
expect(findInputKey().attributes('placeholder')).toBe('Input variable key');
|
|
|
|
expect(findInputValue().attributes('placeholder')).toBe('Input variable value');
|
|
|
|
});
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
it('renders help text with provided link', () => {
|
|
|
|
expect(findHelpText().text()).toBe(
|
|
|
|
'Specify variable values to be used in this run. The values specified in CI/CD settings will be used as default',
|
|
|
|
);
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
expect(wrapper.find('a').attributes('href')).toBe(requiredProps.variablesSettingsUrl);
|
2019-10-12 21:52:04 +05:30
|
|
|
});
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
describe('when adding a new variable', () => {
|
|
|
|
it('creates a new variable when user types a new key and resets the form', async () => {
|
|
|
|
await findInputKey().setValue('new key');
|
|
|
|
|
|
|
|
expect(findAllVariables()).toHaveLength(1);
|
|
|
|
expect(findCiVariableKey().element.value).toBe('new key');
|
|
|
|
expect(findInputKey().attributes('value')).toBe(undefined);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('creates a new variable when user types a new value and resets the form', async () => {
|
|
|
|
await findInputValue().setValue('new value');
|
|
|
|
|
|
|
|
expect(findAllVariables()).toHaveLength(1);
|
|
|
|
expect(findCiVariableValue().element.value).toBe('new value');
|
|
|
|
expect(findInputValue().attributes('value')).toBe(undefined);
|
|
|
|
});
|
2019-10-12 21:52:04 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
describe('mount', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
createComponent({ mountFn: mount });
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when deleting a variable', () => {
|
|
|
|
it('removes the variable row', async () => {
|
|
|
|
await wrapper.setData({
|
|
|
|
variables: [
|
|
|
|
{
|
|
|
|
key: 'new key',
|
|
|
|
secret_value: 'value',
|
|
|
|
id: '1',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
|
|
|
|
findDeleteVarBtn().trigger('click');
|
|
|
|
|
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
|
|
|
|
expect(findAllVariables()).toHaveLength(0);
|
|
|
|
});
|
2020-01-01 13:55:28 +05:30
|
|
|
});
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
it('trigger button is disabled after trigger action', async () => {
|
|
|
|
expect(findTriggerBtn().props('disabled')).toBe(false);
|
|
|
|
|
|
|
|
await findTriggerBtn().trigger('click');
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
expect(findTriggerBtn().props('disabled')).toBe(true);
|
2019-10-12 21:52:04 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|