Files
gitlabhq/spec/frontend/terraform/components/init_command_modal_spec.js
2023-11-08 18:11:30 +00:00

103 lines
3.3 KiB
JavaScript

import { GlLink, GlSprintf } from '@gitlab/ui';
import { shallowMountExtended } from 'helpers/vue_test_utils_helper';
import InitCommandModal from '~/terraform/components/init_command_modal.vue';
import ModalCopyButton from '~/vue_shared/components/modal_copy_button.vue';
const accessTokensPath = '/path/to/access-tokens-page';
const terraformApiUrl = 'https://gitlab.com/api/v4/projects/1';
const username = 'username';
const modalId = 'fake-modal-id';
const stateName = 'aws/eu-central-1';
const stateNameEncoded = encodeURIComponent(stateName);
const modalInfoCopyStr = `export GITLAB_ACCESS_TOKEN=<YOUR-ACCESS-TOKEN>
export TF_STATE_NAME=${stateNameEncoded}
terraform init \\
-backend-config="address=${terraformApiUrl}/$TF_STATE_NAME" \\
-backend-config="lock_address=${terraformApiUrl}/$TF_STATE_NAME/lock" \\
-backend-config="unlock_address=${terraformApiUrl}/$TF_STATE_NAME/lock" \\
-backend-config="username=${username}" \\
-backend-config="password=$GITLAB_ACCESS_TOKEN" \\
-backend-config="lock_method=POST" \\
-backend-config="unlock_method=DELETE" \\
-backend-config="retry_wait_min=5"
`;
describe('InitCommandModal', () => {
let wrapper;
const propsData = {
modalId,
stateName,
};
const provideData = {
accessTokensPath,
terraformApiUrl,
username,
};
const mountComponent = ({ props = propsData } = {}) => {
wrapper = shallowMountExtended(InitCommandModal, {
propsData: props,
provide: provideData,
stubs: {
GlSprintf,
},
});
};
const findExplanatoryText = () => wrapper.findByTestId('init-command-explanatory-text');
const findLink = () => wrapper.findComponent(GlLink);
const findInitCommand = () => wrapper.findByTestId('terraform-init-command');
const findCopyButton = () => wrapper.findComponent(ModalCopyButton);
describe('when has stateName', () => {
beforeEach(() => {
mountComponent();
});
describe('on rendering', () => {
it('renders the explanatory text', () => {
expect(findExplanatoryText().text()).toContain('personal access token');
});
it('renders the personal access token link', () => {
expect(findLink().attributes('href')).toBe(accessTokensPath);
});
describe('init command', () => {
it('includes correct address', () => {
expect(findInitCommand().text()).toContain(
`-backend-config="address=${terraformApiUrl}/$TF_STATE_NAME"`,
);
});
it('includes correct username', () => {
expect(findInitCommand().text()).toContain(`-backend-config="username=${username}"`);
});
});
it('renders the copyToClipboard button', () => {
expect(findCopyButton().exists()).toBe(true);
});
});
describe('when copy button is clicked', () => {
it('copies init command to clipboard', () => {
expect(findCopyButton().props('text')).toBe(modalInfoCopyStr);
});
});
});
describe('when has no stateName', () => {
beforeEach(() => {
mountComponent({ props: { modalId } });
});
describe('on rendering', () => {
it('includes correct address', () => {
expect(findInitCommand().text()).toContain(
`-backend-config="address=${terraformApiUrl}/$TF_STATE_NAME"`,
);
});
});
});
});