Commit 9ea5a016 authored by Axel García's avatar Axel García

Explicit preventDefault on new epic page form

parent 77038586
...@@ -118,7 +118,7 @@ export default { ...@@ -118,7 +118,7 @@ export default {
<h3 class="page-title gl-border-b-solid gl-border-b-gray-100 gl-border-b-1 gl-pb-5 gl-mb-6"> <h3 class="page-title gl-border-b-solid gl-border-b-gray-100 gl-border-b-1 gl-pb-5 gl-mb-6">
{{ __('New Epic') }} {{ __('New Epic') }}
</h3> </h3>
<gl-form class="common-note-form new-epic-form" @submit="save"> <gl-form class="common-note-form new-epic-form" @submit.prevent="save">
<gl-form-group :label="__('Title')" label-for="epic-title"> <gl-form-group :label="__('Title')" label-for="epic-title">
<gl-form-input <gl-form-input
id="epic-title" id="epic-title"
......
---
title: Fix epic creation form submission as it was causing errors on Safari
merge_request: 45721
author:
type: fixed
...@@ -5,8 +5,11 @@ import EpicForm from 'ee/epic/components/epic_form.vue'; ...@@ -5,8 +5,11 @@ import EpicForm from 'ee/epic/components/epic_form.vue';
import createEpic from 'ee/epic/queries/createEpic.mutation.graphql'; import createEpic from 'ee/epic/queries/createEpic.mutation.graphql';
import { TEST_HOST } from 'helpers/test_constants'; import { TEST_HOST } from 'helpers/test_constants';
import LabelsSelectVue from '~/vue_shared/components/sidebar/labels_select_vue/labels_select_root.vue'; import LabelsSelectVue from '~/vue_shared/components/sidebar/labels_select_vue/labels_select_root.vue';
import { visitUrl } from '~/lib/utils/url_utility';
jest.mock('~/lib/utils/url_utility'); jest.mock('~/lib/utils/url_utility', () => ({
visitUrl: jest.fn(),
}));
const TEST_GROUP_PATH = 'gitlab-org'; const TEST_GROUP_PATH = 'gitlab-org';
const TEST_NEW_EPIC = { data: { createEpic: { epic: { webUrl: TEST_HOST } } } }; const TEST_NEW_EPIC = { data: { createEpic: { epic: { webUrl: TEST_HOST } } } };
...@@ -42,6 +45,7 @@ describe('ee/epic/components/epic_form.vue', () => { ...@@ -42,6 +45,7 @@ describe('ee/epic/components/epic_form.vue', () => {
wrapper = null; wrapper = null;
}); });
const findForm = () => wrapper.find(GlForm);
const findLabels = () => wrapper.find(LabelsSelectVue); const findLabels = () => wrapper.find(LabelsSelectVue);
const findTitle = () => wrapper.find('[data-testid="epic-title"]'); const findTitle = () => wrapper.find('[data-testid="epic-title"]');
const findDescription = () => wrapper.find('[data-testid="epic-description"]'); const findDescription = () => wrapper.find('[data-testid="epic-description"]');
...@@ -59,7 +63,7 @@ describe('ee/epic/components/epic_form.vue', () => { ...@@ -59,7 +63,7 @@ describe('ee/epic/components/epic_form.vue', () => {
}); });
it('should render the form', () => { it('should render the form', () => {
expect(wrapper.find(GlForm).exists()).toBe(true); expect(findForm().exists()).toBe(true);
}); });
it('can be canceled', () => { it('can be canceled', () => {
...@@ -107,7 +111,7 @@ describe('ee/epic/components/epic_form.vue', () => { ...@@ -107,7 +111,7 @@ describe('ee/epic/components/epic_form.vue', () => {
findStartDate().vm.$emit('input', startDateFixed); findStartDate().vm.$emit('input', startDateFixed);
findDueDate().vm.$emit('input', dueDateFixed); findDueDate().vm.$emit('input', dueDateFixed);
wrapper.vm.save(); findForm().vm.$emit('submit', { preventDefault: () => {} });
expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledWith({ expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledWith({
mutation: createEpic, mutation: createEpic,
...@@ -125,6 +129,10 @@ describe('ee/epic/components/epic_form.vue', () => { ...@@ -125,6 +129,10 @@ describe('ee/epic/components/epic_form.vue', () => {
}, },
}, },
}); });
await wrapper.vm.$nextTick();
expect(visitUrl).toHaveBeenCalled();
}); });
it.each` it.each`
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment