import { shallowMount } from '@vue/test-utils'; import { nextTick } from 'vue'; import { GlModal } from '@gitlab/ui'; import CommitSection from '~/pipeline_editor/components/commit/commit_section.vue'; import PipelineEditorDrawer from '~/pipeline_editor/components/drawer/pipeline_editor_drawer.vue'; import PipelineEditorFileNav from '~/pipeline_editor/components/file_nav/pipeline_editor_file_nav.vue'; import BranchSwitcher from '~/pipeline_editor/components/file_nav/branch_switcher.vue'; import PipelineEditorHeader from '~/pipeline_editor/components/header/pipeline_editor_header.vue'; import PipelineEditorTabs from '~/pipeline_editor/components/pipeline_editor_tabs.vue'; import { MERGED_TAB, VISUALIZE_TAB, CREATE_TAB, LINT_TAB } from '~/pipeline_editor/constants'; import PipelineEditorHome from '~/pipeline_editor/pipeline_editor_home.vue'; import { mockLintResponse, mockCiYml } from './mock_data'; jest.mock('~/lib/utils/common_utils'); describe('Pipeline editor home wrapper', () => { let wrapper; const createComponent = ({ props = {}, glFeatures = {}, data = {}, stubs = {} } = {}) => { wrapper = shallowMount(PipelineEditorHome, { data: () => data, propsData: { ciConfigData: mockLintResponse, ciFileContent: mockCiYml, isCiConfigDataLoading: false, isNewCiConfigFile: false, ...props, }, provide: { projectFullPath: '', totalBranches: 19, glFeatures: { ...glFeatures, }, }, stubs, }); }; const findBranchSwitcher = () => wrapper.findComponent(BranchSwitcher); const findCommitSection = () => wrapper.findComponent(CommitSection); const findFileNav = () => wrapper.findComponent(PipelineEditorFileNav); const findModal = () => wrapper.findComponent(GlModal); const findPipelineEditorDrawer = () => wrapper.findComponent(PipelineEditorDrawer); const findPipelineEditorHeader = () => wrapper.findComponent(PipelineEditorHeader); const findPipelineEditorTabs = () => wrapper.findComponent(PipelineEditorTabs); afterEach(() => { wrapper.destroy(); }); describe('renders', () => { beforeEach(() => { createComponent(); }); it('shows the file nav', () => { expect(findFileNav().exists()).toBe(true); }); it('shows the pipeline editor header', () => { expect(findPipelineEditorHeader().exists()).toBe(true); }); it('shows the pipeline editor tabs', () => { expect(findPipelineEditorTabs().exists()).toBe(true); }); it('shows the commit section by default', () => { expect(findCommitSection().exists()).toBe(true); }); it('show the pipeline drawer', () => { expect(findPipelineEditorDrawer().exists()).toBe(true); }); }); describe('modal when switching branch', () => { describe('when `showSwitchBranchModal` value is false', () => { beforeEach(() => { createComponent(); }); it('is not visible', () => { expect(findModal().exists()).toBe(false); }); }); describe('when `showSwitchBranchModal` value is true', () => { beforeEach(() => { createComponent({ data: { showSwitchBranchModal: true }, stubs: { PipelineEditorFileNav }, }); }); it('is visible', () => { expect(findModal().exists()).toBe(true); }); it('pass down `shouldLoadNewBranch` to the branch switcher when primary is selected', async () => { expect(findBranchSwitcher().props('shouldLoadNewBranch')).toBe(false); await findModal().vm.$emit('primary'); expect(findBranchSwitcher().props('shouldLoadNewBranch')).toBe(true); }); it('closes the modal when secondary action is selected', async () => { expect(findModal().exists()).toBe(true); await findModal().vm.$emit('secondary'); expect(findModal().exists()).toBe(false); }); }); }); describe('commit form toggle', () => { beforeEach(() => { createComponent(); }); it.each` tab | shouldShow ${MERGED_TAB} | ${false} ${VISUALIZE_TAB} | ${false} ${LINT_TAB} | ${false} ${CREATE_TAB} | ${true} `( 'when the active tab is $tab the commit form is shown: $shouldShow', async ({ tab, shouldShow }) => { expect(findCommitSection().exists()).toBe(true); findPipelineEditorTabs().vm.$emit('set-current-tab', tab); await nextTick(); expect(findCommitSection().exists()).toBe(shouldShow); }, ); it('shows the commit form again when coming back to the create tab', async () => { expect(findCommitSection().exists()).toBe(true); findPipelineEditorTabs().vm.$emit('set-current-tab', MERGED_TAB); await nextTick(); expect(findCommitSection().exists()).toBe(false); findPipelineEditorTabs().vm.$emit('set-current-tab', CREATE_TAB); await nextTick(); expect(findCommitSection().exists()).toBe(true); }); }); describe('WalkthroughPopover events', () => { beforeEach(() => { createComponent(); }); describe('when "walkthrough-popover-cta-clicked" is emitted from pipeline editor tabs', () => { it('passes down `scrollToCommitForm=true` to commit section', async () => { expect(findCommitSection().props('scrollToCommitForm')).toBe(false); await findPipelineEditorTabs().vm.$emit('walkthrough-popover-cta-clicked'); expect(findCommitSection().props('scrollToCommitForm')).toBe(true); }); }); describe('when "scrolled-to-commit-form" is emitted from commit section', () => { it('passes down `scrollToCommitForm=false` to commit section', async () => { await findPipelineEditorTabs().vm.$emit('walkthrough-popover-cta-clicked'); expect(findCommitSection().props('scrollToCommitForm')).toBe(true); await findCommitSection().vm.$emit('scrolled-to-commit-form'); expect(findCommitSection().props('scrollToCommitForm')).toBe(false); }); }); }); });