diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-05-23 18:08:01 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-05-23 18:08:01 +0300 |
commit | abdb550f6937ce69ec38954f24ef221d07637438 (patch) | |
tree | a8f2136768637c628f544f567fa57d63c5cf6e3b /spec/frontend/ci/pipeline_editor | |
parent | e6d048d769240760008f0dbb6b811e1ebc675292 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/frontend/ci/pipeline_editor')
-rw-r--r-- | spec/frontend/ci/pipeline_editor/components/validate/ci_validate_spec.js | 171 | ||||
-rw-r--r-- | spec/frontend/ci/pipeline_editor/mock_data.js | 8 |
2 files changed, 85 insertions, 94 deletions
diff --git a/spec/frontend/ci/pipeline_editor/components/validate/ci_validate_spec.js b/spec/frontend/ci/pipeline_editor/components/validate/ci_validate_spec.js index 2349816fa86..f2818277c59 100644 --- a/spec/frontend/ci/pipeline_editor/components/validate/ci_validate_spec.js +++ b/spec/frontend/ci/pipeline_editor/components/validate/ci_validate_spec.js @@ -1,15 +1,20 @@ +import Vue from 'vue'; import { GlAlert, GlDisclosureDropdown, GlIcon, GlLoadingIcon, GlPopover } from '@gitlab/ui'; -import { nextTick } from 'vue'; -import { createLocalVue } from '@vue/test-utils'; import VueApollo from 'vue-apollo'; +import MockAdapter from 'axios-mock-adapter'; + import { mockTracking, unmockTracking } from 'helpers/tracking_helper'; import { shallowMountExtended } from 'helpers/vue_test_utils_helper'; import createMockApollo from 'helpers/mock_apollo_helper'; +import waitForPromises from 'helpers/wait_for_promises'; + +import axios from '~/lib/utils/axios_utils'; +import { HTTP_STATUS_OK } from '~/lib/utils/http_status'; +import { resolvers } from '~/ci/pipeline_editor/graphql/resolvers'; import CiLintResults from '~/ci/pipeline_editor/components/lint/ci_lint_results.vue'; import CiValidate, { i18n } from '~/ci/pipeline_editor/components/validate/ci_validate.vue'; import ValidatePipelinePopover from '~/ci/pipeline_editor/components/popovers/validate_pipeline_popover.vue'; import getBlobContent from '~/ci/pipeline_editor/graphql/queries/blob_content.query.graphql'; -import lintCIMutation from '~/ci/pipeline_editor/graphql/mutations/client/lint_ci.mutation.graphql'; import { pipelineEditorTrackingOptions } from '~/ci/pipeline_editor/constants'; import { mockBlobContentQueryResponse, @@ -17,68 +22,45 @@ import { mockCiYml, mockSimulatePipelineHelpPagePath, } from '../../mock_data'; -import { mockLintDataError, mockLintDataValid } from '../../../ci_lint/mock_data'; +import { + mockLintDataError, + mockLintDataValid, + mockLintDataErrorRest, + mockLintDataValidRest, +} from '../../../ci_lint/mock_data'; + +let mockAxios; + +Vue.use(VueApollo); -const localVue = createLocalVue(); -localVue.use(VueApollo); +const defaultProvide = { + ciConfigPath: '/path/to/ci-config', + ciLintPath: mockCiLintPath, + currentBranch: 'main', + projectFullPath: '/path/to/project', + validateTabIllustrationPath: '/path/to/img', + simulatePipelineHelpPagePath: mockSimulatePipelineHelpPagePath, +}; describe('Pipeline Editor Validate Tab', () => { let wrapper; - let mockApollo; let mockBlobContentData; let trackingSpy; - const createComponent = ({ - props, - stubs, - options, - isBlobLoading = false, - isSimulationLoading = false, - } = {}) => { + const createComponent = ({ props, stubs } = {}) => { + const handlers = [[getBlobContent, mockBlobContentData]]; + const mockApollo = createMockApollo(handlers, resolvers); + wrapper = shallowMountExtended(CiValidate, { propsData: { ciFileContent: mockCiYml, ...props, }, - provide: { - ciConfigPath: '/path/to/ci-config', - ciLintPath: mockCiLintPath, - currentBranch: 'main', - projectFullPath: '/path/to/project', - validateTabIllustrationPath: '/path/to/img', - simulatePipelineHelpPagePath: mockSimulatePipelineHelpPagePath, - }, - stubs, - mocks: { - $apollo: { - queries: { - initialBlobContent: { - loading: isBlobLoading, - }, - }, - mutations: { - lintCiMutation: { - loading: isSimulationLoading, - }, - }, - }, - }, - ...options, - }); - }; - - const createComponentWithApollo = ({ props, stubs } = {}) => { - const handlers = [[getBlobContent, mockBlobContentData]]; - mockApollo = createMockApollo(handlers); - - createComponent({ - props, stubs, - options: { - localVue, - apolloProvider: mockApollo, - mocks: {}, + provide: { + ...defaultProvide, }, + apolloProvider: mockApollo, }); }; @@ -96,12 +78,21 @@ describe('Pipeline Editor Validate Tab', () => { const findResultsCta = () => wrapper.findByTestId('resimulate-pipeline-button'); beforeEach(() => { + mockAxios = new MockAdapter(axios); + mockAxios.onPost(defaultProvide.ciLintPath).reply(HTTP_STATUS_OK, mockLintDataValidRest); + mockBlobContentData = jest.fn(); }); + afterEach(() => { + mockAxios.restore(); + }); + describe('while initial CI content is loading', () => { beforeEach(() => { - createComponent({ isBlobLoading: true }); + mockBlobContentData.mockResolvedValue(mockBlobContentQueryResponse); + + createComponent(); }); it('renders disabled CTA with tooltip', () => { @@ -113,7 +104,7 @@ describe('Pipeline Editor Validate Tab', () => { describe('after initial CI content is loaded', () => { beforeEach(async () => { mockBlobContentData.mockResolvedValue(mockBlobContentQueryResponse); - await createComponentWithApollo({ stubs: { GlPopover, ValidatePipelinePopover } }); + await createComponent({ stubs: { GlPopover, ValidatePipelinePopover } }); }); it('renders disabled pipeline source dropdown', () => { @@ -137,10 +128,9 @@ describe('Pipeline Editor Validate Tab', () => { describe('simulating the pipeline', () => { beforeEach(async () => { mockBlobContentData.mockResolvedValue(mockBlobContentQueryResponse); - await createComponentWithApollo(); + await createComponent(); trackingSpy = mockTracking(undefined, wrapper.element, jest.spyOn); - jest.spyOn(wrapper.vm.$apollo, 'mutate').mockResolvedValue(mockLintDataValid); }); afterEach(() => { @@ -158,32 +148,32 @@ describe('Pipeline Editor Validate Tab', () => { }); it('renders loading state while simulation is ongoing', async () => { - findCta().vm.$emit('click'); - await nextTick(); + await findCta().vm.$emit('click'); expect(findLoadingIcon().exists()).toBe(true); expect(findCancelBtn().exists()).toBe(true); expect(findCta().props('loading')).toBe(true); }); - it('calls mutation with the correct input', async () => { - await findCta().vm.$emit('click'); + it('calls endpoint with the correct input', async () => { + findCta().vm.$emit('click'); + + await waitForPromises(); - expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledTimes(1); - expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledWith({ - mutation: lintCIMutation, - variables: { - dry: true, + expect(mockAxios.history.post).toHaveLength(1); + expect(mockAxios.history.post[0].data).toBe( + JSON.stringify({ content: mockCiYml, - endpoint: mockCiLintPath, - }, - }); + dry_run: true, + }), + ); }); describe('when results are successful', () => { beforeEach(async () => { - jest.spyOn(wrapper.vm.$apollo, 'mutate').mockResolvedValue(mockLintDataValid); - await findCta().vm.$emit('click'); + findCta().vm.$emit('click'); + + await waitForPromises(); }); it('renders success alert', () => { @@ -210,8 +200,10 @@ describe('Pipeline Editor Validate Tab', () => { describe('when results have errors', () => { beforeEach(async () => { - jest.spyOn(wrapper.vm.$apollo, 'mutate').mockResolvedValue(mockLintDataError); - await findCta().vm.$emit('click'); + mockAxios.onPost(defaultProvide.ciLintPath).reply(HTTP_STATUS_OK, mockLintDataErrorRest); + findCta().vm.$emit('click'); + + await waitForPromises(); }); it('renders error alert', () => { @@ -236,11 +228,11 @@ describe('Pipeline Editor Validate Tab', () => { describe('when CI content has changed after a simulation', () => { beforeEach(async () => { mockBlobContentData.mockResolvedValue(mockBlobContentQueryResponse); - await createComponentWithApollo(); + await createComponent(); trackingSpy = mockTracking(undefined, wrapper.element, jest.spyOn); - jest.spyOn(wrapper.vm.$apollo, 'mutate').mockResolvedValue(mockLintDataValid); - await findCta().vm.$emit('click'); + findCta().vm.$emit('click'); + await waitForPromises(); }); afterEach(() => { @@ -267,25 +259,26 @@ describe('Pipeline Editor Validate Tab', () => { }); it('calls mutation with new content', async () => { - await wrapper.setProps({ ciFileContent: 'new yaml content' }); - await findResultsCta().vm.$emit('click'); - - expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledTimes(2); - expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledWith({ - mutation: lintCIMutation, - variables: { - dry: true, - content: 'new yaml content', - endpoint: mockCiLintPath, - }, - }); + const newContent = 'new yaml content'; + await wrapper.setProps({ ciFileContent: newContent }); + findResultsCta().vm.$emit('click'); + + await waitForPromises(); + + expect(mockAxios.history.post).toHaveLength(2); + expect(mockAxios.history.post[1].data).toBe( + JSON.stringify({ + content: newContent, + dry_run: true, + }), + ); }); }); describe('canceling a simulation', () => { beforeEach(async () => { mockBlobContentData.mockResolvedValue(mockBlobContentQueryResponse); - await createComponentWithApollo(); + await createComponent(); }); it('returns to init state', async () => { @@ -294,9 +287,7 @@ describe('Pipeline Editor Validate Tab', () => { expect(findCiLintResults().exists()).toBe(false); // mutations should have successful results - jest.spyOn(wrapper.vm.$apollo, 'mutate').mockResolvedValue(mockLintDataValid); - findCta().vm.$emit('click'); - await nextTick(); + await findCta().vm.$emit('click'); // cancel before simulation succeeds expect(findCancelBtn().exists()).toBe(true); diff --git a/spec/frontend/ci/pipeline_editor/mock_data.js b/spec/frontend/ci/pipeline_editor/mock_data.js index 865dd34fbfe..dddf2dd7602 100644 --- a/spec/frontend/ci/pipeline_editor/mock_data.js +++ b/spec/frontend/ci/pipeline_editor/mock_data.js @@ -43,7 +43,7 @@ job_build: export const mockCiTemplateQueryResponse = { data: { project: { - id: 'project-1', + id: 'gid://gitlab/Project/1', ciTemplate: { content: mockCiYml, }, @@ -54,7 +54,7 @@ export const mockCiTemplateQueryResponse = { export const mockBlobContentQueryResponse = { data: { project: { - id: 'project-1', + id: 'gid://gitlab/Project/1', repository: { blobs: { nodes: [{ id: 'blob-1', rawBlob: mockCiYml }] } }, }, }, @@ -62,13 +62,13 @@ export const mockBlobContentQueryResponse = { export const mockBlobContentQueryResponseNoCiFile = { data: { - project: { id: 'project-1', repository: { blobs: { nodes: [] } } }, + project: { id: 'gid://gitlab/Project/1', repository: { blobs: { nodes: [] } } }, }, }; export const mockBlobContentQueryResponseEmptyCiFile = { data: { - project: { id: 'project-1', repository: { blobs: { nodes: [{ rawBlob: '' }] } } }, + project: { id: 'gid://gitlab/Project/1', repository: { blobs: { nodes: [{ rawBlob: '' }] } } }, }, }; |