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/projects/experiment_new_project_creation/components/app_spec.js')
-rw-r--r--spec/frontend/projects/experiment_new_project_creation/components/app_spec.js144
1 files changed, 0 insertions, 144 deletions
diff --git a/spec/frontend/projects/experiment_new_project_creation/components/app_spec.js b/spec/frontend/projects/experiment_new_project_creation/components/app_spec.js
deleted file mode 100644
index 204e7a7c394..00000000000
--- a/spec/frontend/projects/experiment_new_project_creation/components/app_spec.js
+++ /dev/null
@@ -1,144 +0,0 @@
-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: '<h4>Internal Guidelines</h4><p>lorem ipsum</p>',
- });
- expect(wrapper.find(guidelineSelector).exists()).toBe(true);
- expect(wrapper.find(guidelineSelector).html()).toContain('<h4>Internal Guidelines</h4>');
- expect(wrapper.find(guidelineSelector).html()).toContain('<p>lorem ipsum</p>');
- });
- });
-
- 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);
- });
- });
-});