Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/frontend/vue_shared/components/security_reports/artifact_downloads/merge_request_artifact_download_spec.js')
-rw-r--r--spec/frontend/vue_shared/components/security_reports/artifact_downloads/merge_request_artifact_download_spec.js108
1 files changed, 108 insertions, 0 deletions
diff --git a/spec/frontend/vue_shared/components/security_reports/artifact_downloads/merge_request_artifact_download_spec.js b/spec/frontend/vue_shared/components/security_reports/artifact_downloads/merge_request_artifact_download_spec.js
new file mode 100644
index 00000000000..d58c87d66cb
--- /dev/null
+++ b/spec/frontend/vue_shared/components/security_reports/artifact_downloads/merge_request_artifact_download_spec.js
@@ -0,0 +1,108 @@
+import { shallowMount } from '@vue/test-utils';
+import Vue from 'vue';
+import VueApollo from 'vue-apollo';
+import createMockApollo from 'helpers/mock_apollo_helper';
+import {
+ expectedDownloadDropdownProps,
+ securityReportMergeRequestDownloadPathsQueryResponse,
+} from 'jest/vue_shared/security_reports/mock_data';
+import createFlash from '~/flash';
+import Component from '~/vue_shared/security_reports/components/artifact_downloads/merge_request_artifact_download.vue';
+import SecurityReportDownloadDropdown from '~/vue_shared/security_reports/components/security_report_download_dropdown.vue';
+import {
+ REPORT_TYPE_SAST,
+ REPORT_TYPE_SECRET_DETECTION,
+} from '~/vue_shared/security_reports/constants';
+import securityReportMergeRequestDownloadPathsQuery from '~/vue_shared/security_reports/queries/security_report_merge_request_download_paths.query.graphql';
+
+jest.mock('~/flash');
+
+describe('Merge request artifact Download', () => {
+ let wrapper;
+
+ const defaultProps = {
+ reportTypes: [REPORT_TYPE_SAST, REPORT_TYPE_SECRET_DETECTION],
+ targetProjectFullPath: '/path',
+ mrIid: 123,
+ };
+
+ const createWrapper = ({ propsData, options }) => {
+ wrapper = shallowMount(Component, {
+ stubs: {
+ SecurityReportDownloadDropdown,
+ },
+ propsData: {
+ ...defaultProps,
+ ...propsData,
+ },
+ ...options,
+ });
+ };
+
+ const pendingHandler = () => new Promise(() => {});
+ const successHandler = () =>
+ Promise.resolve({ data: securityReportMergeRequestDownloadPathsQueryResponse });
+ const failureHandler = () => Promise.resolve({ errors: [{ message: 'some error' }] });
+ const createMockApolloProvider = (handler) => {
+ Vue.use(VueApollo);
+ const requestHandlers = [[securityReportMergeRequestDownloadPathsQuery, handler]];
+
+ return createMockApollo(requestHandlers);
+ };
+
+ const findDownloadDropdown = () => wrapper.find(SecurityReportDownloadDropdown);
+
+ afterEach(() => {
+ wrapper.destroy();
+ });
+
+ describe('given the query is loading', () => {
+ beforeEach(() => {
+ createWrapper({
+ options: {
+ apolloProvider: createMockApolloProvider(pendingHandler),
+ },
+ });
+ });
+
+ it('loading is true', () => {
+ expect(findDownloadDropdown().props('loading')).toBe(true);
+ });
+ });
+
+ describe('given the query loads successfully', () => {
+ beforeEach(() => {
+ createWrapper({
+ options: {
+ apolloProvider: createMockApolloProvider(successHandler),
+ },
+ });
+ });
+
+ it('renders the download dropdown', () => {
+ expect(findDownloadDropdown().props()).toEqual(expectedDownloadDropdownProps);
+ });
+ });
+
+ describe('given the query fails', () => {
+ beforeEach(() => {
+ createWrapper({
+ options: {
+ apolloProvider: createMockApolloProvider(failureHandler),
+ },
+ });
+ });
+
+ it('calls createFlash correctly', () => {
+ expect(createFlash).toHaveBeenCalledWith({
+ message: Component.i18n.apiError,
+ captureError: true,
+ error: expect.any(Error),
+ });
+ });
+
+ it('renders nothing', () => {
+ expect(findDownloadDropdown().props('artifacts')).toEqual([]);
+ });
+ });
+});