import { GlBreadcrumb } from '@gitlab/ui'; import { shallowMount } from '@vue/test-utils'; import { assignGitlabExperiment } from 'helpers/experimentation_helper'; import App from '~/projects/experiment_new_project_creation/components/app.vue'; import LegacyContainer from '~/projects/experiment_new_project_creation/components/legacy_container.vue'; import WelcomePage from '~/projects/experiment_new_project_creation/components/welcome.vue'; describe('Experimental new project creation app', () => { let wrapper; const createComponent = (propsData) => { wrapper = shallowMount(App, { propsData }); }; afterEach(() => { wrapper.destroy(); window.location.hash = ''; wrapper = null; }); const findWelcomePage = () => wrapper.findComponent(WelcomePage); const findPanel = (panelName) => findWelcomePage() .props() .panels.find((p) => p.name === panelName); const findPanelHeader = () => wrapper.find('h4'); describe('new_repo experiment', () => { describe('when in the candidate variant', () => { assignGitlabExperiment('new_repo', 'candidate'); it('has "repository" in the panel title', () => { createComponent(); expect(findPanel('blank_project').title).toBe('Create blank project/repository'); }); describe('when hash is not empty on load', () => { beforeEach(() => { window.location.hash = '#blank_project'; createComponent(); }); it('renders "project/repository"', () => { expect(findPanelHeader().text()).toBe('Create blank project/repository'); }); }); }); describe('when in the control variant', () => { assignGitlabExperiment('new_repo', 'control'); it('has "project" in the panel title', () => { createComponent(); expect(findPanel('blank_project').title).toBe('Create blank project'); }); describe('when hash is not empty on load', () => { beforeEach(() => { window.location.hash = '#blank_project'; createComponent(); }); it('renders "project"', () => { expect(findPanelHeader().text()).toBe('Create blank project'); }); }); }); }); describe('with empty hash', () => { beforeEach(() => { createComponent(); }); it('renders welcome page', () => { expect(wrapper.find(WelcomePage).exists()).toBe(true); }); it('does not render breadcrumbs', () => { expect(wrapper.find(GlBreadcrumb).exists()).toBe(false); }); }); it('renders blank project container if there are errors', () => { createComponent({ hasErrors: true }); expect(wrapper.find(WelcomePage).exists()).toBe(false); expect(wrapper.find(LegacyContainer).exists()).toBe(true); }); describe('when hash is not empty on load', () => { beforeEach(() => { window.location.hash = '#blank_project'; createComponent(); }); it('renders relevant container', () => { expect(wrapper.find(WelcomePage).exists()).toBe(false); expect(wrapper.find(LegacyContainer).exists()).toBe(true); }); it('renders breadcrumbs', () => { expect(wrapper.find(GlBreadcrumb).exists()).toBe(true); }); }); describe('display custom new project guideline text', () => { beforeEach(() => { window.location.hash = '#blank_project'; }); it('does not render new project guideline if undefined', () => { createComponent(); expect(wrapper.find('div#new-project-guideline').exists()).toBe(false); }); it('render new project guideline if defined', () => { const guidelineSelector = 'div#new-project-guideline'; createComponent({ newProjectGuidelines: '

Internal Guidelines

lorem ipsum

', }); expect(wrapper.find(guidelineSelector).exists()).toBe(true); expect(wrapper.find(guidelineSelector).html()).toContain('

Internal Guidelines

'); expect(wrapper.find(guidelineSelector).html()).toContain('

lorem ipsum

'); }); }); it('renders relevant container when hash changes', () => { createComponent(); expect(wrapper.find(WelcomePage).exists()).toBe(true); window.location.hash = '#blank_project'; const ev = document.createEvent('HTMLEvents'); ev.initEvent('hashchange', false, false); window.dispatchEvent(ev); return wrapper.vm.$nextTick().then(() => { expect(wrapper.find(WelcomePage).exists()).toBe(false); expect(wrapper.find(LegacyContainer).exists()).toBe(true); }); }); });