2020-01-01 13:55:28 +05:30
|
|
|
import { mount } from '@vue/test-utils';
|
|
|
|
import DeploymentComponent from '~/vue_merge_request_widget/components/deployment/deployment.vue';
|
|
|
|
import DeploymentInfo from '~/vue_merge_request_widget/components/deployment/deployment_info.vue';
|
|
|
|
import DeploymentViewButton from '~/vue_merge_request_widget/components/deployment/deployment_view_button.vue';
|
|
|
|
import {
|
|
|
|
CREATED,
|
|
|
|
RUNNING,
|
|
|
|
SUCCESS,
|
|
|
|
FAILED,
|
|
|
|
CANCELED,
|
|
|
|
} from '~/vue_merge_request_widget/components/deployment/constants';
|
2020-04-08 14:13:33 +05:30
|
|
|
import { deploymentMockData, playDetails, retryDetails } from './deployment_mock_data';
|
2020-01-01 13:55:28 +05:30
|
|
|
|
|
|
|
describe('Deployment component', () => {
|
|
|
|
let wrapper;
|
|
|
|
|
|
|
|
const factory = (options = {}) => {
|
|
|
|
// This destroys any wrappers created before a nested call to factory reassigns it
|
|
|
|
if (wrapper && wrapper.destroy) {
|
|
|
|
wrapper.destroy();
|
|
|
|
}
|
|
|
|
wrapper = mount(DeploymentComponent, {
|
|
|
|
...options,
|
2020-04-08 14:13:33 +05:30
|
|
|
provide: { glFeatures: { deployFromFooter: true } },
|
2020-01-01 13:55:28 +05:30
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
factory({
|
|
|
|
propsData: {
|
|
|
|
deployment: deploymentMockData,
|
|
|
|
showMetrics: false,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
wrapper.destroy();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('always renders DeploymentInfo', () => {
|
|
|
|
expect(wrapper.find(DeploymentInfo).exists()).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('status message and buttons', () => {
|
|
|
|
const noActions = [];
|
|
|
|
const noDetails = { isManual: false };
|
2020-04-08 14:13:33 +05:30
|
|
|
const deployDetail = {
|
|
|
|
...playDetails,
|
|
|
|
isManual: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
const retryDetail = {
|
|
|
|
...retryDetails,
|
|
|
|
isManual: true,
|
|
|
|
};
|
|
|
|
const defaultGroup = ['.js-deploy-url', '.js-stop-env'];
|
|
|
|
const manualDeployGroup = ['.js-manual-deploy-action', ...defaultGroup];
|
|
|
|
const manualRedeployGroup = ['.js-manual-redeploy-action', ...defaultGroup];
|
2020-01-01 13:55:28 +05:30
|
|
|
|
|
|
|
describe.each`
|
2020-03-13 15:44:24 +05:30
|
|
|
status | previous | deploymentDetails | text | actionButtons
|
2020-04-08 14:13:33 +05:30
|
|
|
${CREATED} | ${true} | ${deployDetail} | ${'Can be manually deployed to'} | ${manualDeployGroup}
|
|
|
|
${CREATED} | ${true} | ${noDetails} | ${'Will deploy to'} | ${defaultGroup}
|
2020-03-13 15:44:24 +05:30
|
|
|
${CREATED} | ${false} | ${deployDetail} | ${'Can be manually deployed to'} | ${noActions}
|
|
|
|
${CREATED} | ${false} | ${noDetails} | ${'Will deploy to'} | ${noActions}
|
2020-04-08 14:13:33 +05:30
|
|
|
${RUNNING} | ${true} | ${deployDetail} | ${'Deploying to'} | ${defaultGroup}
|
|
|
|
${RUNNING} | ${true} | ${noDetails} | ${'Deploying to'} | ${defaultGroup}
|
2020-03-13 15:44:24 +05:30
|
|
|
${RUNNING} | ${false} | ${deployDetail} | ${'Deploying to'} | ${noActions}
|
|
|
|
${RUNNING} | ${false} | ${noDetails} | ${'Deploying to'} | ${noActions}
|
2020-04-08 14:13:33 +05:30
|
|
|
${SUCCESS} | ${true} | ${deployDetail} | ${'Deployed to'} | ${defaultGroup}
|
|
|
|
${SUCCESS} | ${true} | ${noDetails} | ${'Deployed to'} | ${defaultGroup}
|
|
|
|
${SUCCESS} | ${false} | ${deployDetail} | ${'Deployed to'} | ${defaultGroup}
|
|
|
|
${SUCCESS} | ${false} | ${noDetails} | ${'Deployed to'} | ${defaultGroup}
|
|
|
|
${FAILED} | ${true} | ${retryDetail} | ${'Failed to deploy to'} | ${manualRedeployGroup}
|
|
|
|
${FAILED} | ${true} | ${noDetails} | ${'Failed to deploy to'} | ${defaultGroup}
|
|
|
|
${FAILED} | ${false} | ${retryDetail} | ${'Failed to deploy to'} | ${noActions}
|
2020-03-13 15:44:24 +05:30
|
|
|
${FAILED} | ${false} | ${noDetails} | ${'Failed to deploy to'} | ${noActions}
|
2020-04-08 14:13:33 +05:30
|
|
|
${CANCELED} | ${true} | ${deployDetail} | ${'Canceled deployment to'} | ${defaultGroup}
|
|
|
|
${CANCELED} | ${true} | ${noDetails} | ${'Canceled deployment to'} | ${defaultGroup}
|
2020-03-13 15:44:24 +05:30
|
|
|
${CANCELED} | ${false} | ${deployDetail} | ${'Canceled deployment to'} | ${noActions}
|
|
|
|
${CANCELED} | ${false} | ${noDetails} | ${'Canceled deployment to'} | ${noActions}
|
2020-01-01 13:55:28 +05:30
|
|
|
`(
|
|
|
|
'$status + previous: $previous + manual: $deploymentDetails.isManual',
|
|
|
|
({ status, previous, deploymentDetails, text, actionButtons }) => {
|
|
|
|
beforeEach(() => {
|
|
|
|
const previousOrSuccess = Boolean(previous || status === SUCCESS);
|
|
|
|
const updatedDeploymentData = {
|
|
|
|
status,
|
|
|
|
deployed_at: previous ? deploymentMockData.deployed_at : null,
|
|
|
|
deployed_at_formatted: previous ? deploymentMockData.deployed_at_formatted : null,
|
|
|
|
external_url: previousOrSuccess ? deploymentMockData.external_url : null,
|
|
|
|
external_url_formatted: previousOrSuccess
|
|
|
|
? deploymentMockData.external_url_formatted
|
|
|
|
: null,
|
|
|
|
stop_url: previousOrSuccess ? deploymentMockData.stop_url : null,
|
|
|
|
details: deploymentDetails,
|
|
|
|
};
|
|
|
|
|
|
|
|
factory({
|
|
|
|
propsData: {
|
|
|
|
showMetrics: false,
|
|
|
|
deployment: {
|
|
|
|
...deploymentMockData,
|
|
|
|
...updatedDeploymentData,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`renders the text: ${text}`, () => {
|
|
|
|
expect(wrapper.find(DeploymentInfo).text()).toContain(text);
|
|
|
|
});
|
|
|
|
|
|
|
|
if (actionButtons.length > 0) {
|
|
|
|
describe('renders the expected button group', () => {
|
|
|
|
actionButtons.forEach(button => {
|
2020-04-08 14:13:33 +05:30
|
|
|
it(`renders ${button}`, () => {
|
2020-01-01 13:55:28 +05:30
|
|
|
expect(wrapper.find(button).exists()).toBe(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (actionButtons.length === 0) {
|
|
|
|
describe('does not render the button group', () => {
|
2020-04-08 14:13:33 +05:30
|
|
|
defaultGroup.forEach(button => {
|
|
|
|
it(`does not render ${button}`, () => {
|
2020-01-01 13:55:28 +05:30
|
|
|
expect(wrapper.find(button).exists()).toBe(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if (actionButtons.includes(DeploymentViewButton)) {
|
|
|
|
it('renders the View button with expected text', () => {
|
|
|
|
if (status === SUCCESS) {
|
|
|
|
expect(wrapper.find(DeploymentViewButton).text()).toContain('View app');
|
|
|
|
} else {
|
2020-03-13 15:44:24 +05:30
|
|
|
expect(wrapper.find(DeploymentViewButton).text()).toContain('View latest app');
|
2020-01-01 13:55:28 +05:30
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('hasExternalUrls', () => {
|
|
|
|
describe('when deployment has both external_url_formatted and external_url', () => {
|
|
|
|
it('should render the View Button', () => {
|
|
|
|
expect(wrapper.find(DeploymentViewButton).exists()).toBe(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when deployment has no external_url_formatted', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
factory({
|
|
|
|
propsData: {
|
|
|
|
deployment: { ...deploymentMockData, external_url_formatted: null },
|
|
|
|
showMetrics: false,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not render the View Button', () => {
|
|
|
|
expect(wrapper.find(DeploymentViewButton).exists()).toBe(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when deployment has no external_url', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
factory({
|
|
|
|
propsData: {
|
|
|
|
deployment: { ...deploymentMockData, external_url: null },
|
|
|
|
showMetrics: false,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not render the View Button', () => {
|
|
|
|
expect(wrapper.find(DeploymentViewButton).exists()).toBe(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|