Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
ae06e067
Commit
ae06e067
authored
Jul 27, 2021
by
Olena Horal-Koretska
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Validate timezone presence on schedule creation form
Changelog: fixed EE: true
parent
fa94c4a2
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
71 additions
and
54 deletions
+71
-54
ee/app/assets/javascripts/oncall_schedules/components/add_edit_schedule_modal.vue
...s/oncall_schedules/components/add_edit_schedule_modal.vue
+12
-1
ee/spec/frontend/oncall_schedule/add_edit_schedule_modal_spec.js
.../frontend/oncall_schedule/add_edit_schedule_modal_spec.js
+59
-53
No files found.
ee/app/assets/javascripts/oncall_schedules/components/add_edit_schedule_modal.vue
View file @
ae06e067
...
@@ -96,7 +96,16 @@ export default {
...
@@ -96,7 +96,16 @@ export default {
},
},
},
},
methods
:
{
methods
:
{
triggerFormValidation
()
{
this
.
validateForm
(
'
timezone
'
);
},
createSchedule
()
{
createSchedule
()
{
this
.
triggerFormValidation
();
if
(
!
this
.
isFormValid
)
{
return
;
}
this
.
loading
=
true
;
this
.
loading
=
true
;
const
{
projectPath
}
=
this
;
const
{
projectPath
}
=
this
;
...
@@ -127,6 +136,7 @@ export default {
...
@@ -127,6 +136,7 @@ export default {
if
(
error
)
{
if
(
error
)
{
throw
error
;
throw
error
;
}
}
this
.
$refs
.
addUpdateScheduleModal
.
hide
();
this
.
$refs
.
addUpdateScheduleModal
.
hide
();
this
.
$emit
(
'
scheduleCreated
'
);
this
.
$emit
(
'
scheduleCreated
'
);
this
.
clearScheduleForm
();
this
.
clearScheduleForm
();
...
@@ -140,11 +150,12 @@ export default {
...
@@ -140,11 +150,12 @@ export default {
});
});
},
},
editSchedule
()
{
editSchedule
()
{
this
.
loading
=
true
;
const
{
const
{
projectPath
,
projectPath
,
form
:
{
timezone
},
form
:
{
timezone
},
}
=
this
;
}
=
this
;
this
.
loading
=
true
;
this
.
$apollo
this
.
$apollo
.
mutate
({
.
mutate
({
...
...
ee/spec/frontend/oncall_schedule/add_edit_schedule_modal_spec.js
View file @
ae06e067
import
{
GlModal
,
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
GlModal
,
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
AddEditScheduleForm
from
'
ee/oncall_schedules/components/add_edit_schedule_form.vue
'
;
import
AddEditScheduleForm
from
'
ee/oncall_schedules/components/add_edit_schedule_form.vue
'
;
import
AddEditScheduleModal
,
{
import
AddEditScheduleModal
,
{
...
@@ -58,9 +59,9 @@ describe('AddScheduleModal', () => {
...
@@ -58,9 +59,9 @@ describe('AddScheduleModal', () => {
};
};
async
function
awaitApolloDomMock
()
{
async
function
awaitApolloDomMock
()
{
await
wrapper
.
vm
.
$
nextTick
();
// kick off the DOM update
await
nextTick
();
// kick off the DOM update
await
jest
.
runOnlyPendingTimers
();
// kick off the mocked GQL stuff (promises)
await
jest
.
runOnlyPendingTimers
();
// kick off the mocked GQL stuff (promises)
await
wrapper
.
vm
.
$
nextTick
();
// kick off the DOM update for flash
await
nextTick
();
// kick off the DOM update for flash
}
}
async
function
updateSchedule
(
localWrapper
)
{
async
function
updateSchedule
(
localWrapper
)
{
...
@@ -119,6 +120,8 @@ describe('AddScheduleModal', () => {
...
@@ -119,6 +120,8 @@ describe('AddScheduleModal', () => {
const
findAlert
=
()
=>
wrapper
.
findComponent
(
GlAlert
);
const
findAlert
=
()
=>
wrapper
.
findComponent
(
GlAlert
);
const
findModalForm
=
()
=>
wrapper
.
findComponent
(
AddEditScheduleForm
);
const
findModalForm
=
()
=>
wrapper
.
findComponent
(
AddEditScheduleForm
);
const
submitForm
=
()
=>
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
describe
(
'
Schedule create
'
,
()
=>
{
describe
(
'
Schedule create
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
createComponent
({
modalId
:
addScheduleModalId
});
createComponent
({
modalId
:
addScheduleModalId
});
...
@@ -134,9 +137,32 @@ describe('AddScheduleModal', () => {
...
@@ -134,9 +137,32 @@ describe('AddScheduleModal', () => {
});
});
});
});
it
(
'
makes a request with form data to create a schedule
'
,
()
=>
{
it
(
'
prevents form submit if schedule is invalid
'
,
()
=>
{
mutate
.
mockResolvedValueOnce
({});
createComponent
({
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
modalId
:
addScheduleModalId
,
data
:
{
form
:
{
name
:
'
schedule
'
,
timezone
:
null
}
},
});
submitForm
();
expect
(
mutate
).
not
.
toHaveBeenCalled
();
});
it
(
"
doesn't hide a modal and shows error alert on fail
"
,
async
()
=>
{
const
error
=
'
some error
'
;
mutate
.
mockImplementation
(()
=>
Promise
.
reject
(
error
));
submitForm
();
await
waitForPromises
();
const
alert
=
findAlert
();
expect
(
mockHideModal
).
not
.
toHaveBeenCalled
();
expect
(
alert
.
exists
()).
toBe
(
true
);
expect
(
alert
.
text
()).
toContain
(
error
);
});
it
(
'
makes a request with form data to create a schedule and hides a modal
'
,
async
()
=>
{
mutate
.
mockImplementation
(()
=>
Promise
.
resolve
({
data
:
{
oncallScheduleCreate
:
{
errors
:
[]
}
}
}),
);
submitForm
();
expect
(
mutate
).
toHaveBeenCalledWith
({
expect
(
mutate
).
toHaveBeenCalledWith
({
mutation
:
expect
.
any
(
Object
),
mutation
:
expect
.
any
(
Object
),
update
:
expect
.
any
(
Function
),
update
:
expect
.
any
(
Function
),
...
@@ -148,29 +174,15 @@ describe('AddScheduleModal', () => {
...
@@ -148,29 +174,15 @@ describe('AddScheduleModal', () => {
},
},
},
},
});
});
});
it
(
'
hides the modal on successful schedule creation
'
,
async
()
=>
{
mutate
.
mockResolvedValueOnce
({
data
:
{
oncallScheduleCreate
:
{
errors
:
[]
}
}
});
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
await
waitForPromises
();
await
waitForPromises
();
expect
(
mockHideModal
).
toHaveBeenCalled
();
expect
(
mockHideModal
).
toHaveBeenCalled
();
});
});
it
(
"
doesn't hide a modal and shows error alert on fail
"
,
async
()
=>
{
const
error
=
'
some error
'
;
mutate
.
mockResolvedValueOnce
({
data
:
{
oncallScheduleCreate
:
{
errors
:
[
error
]
}
}
});
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
await
waitForPromises
();
const
alert
=
findAlert
();
expect
(
mockHideModal
).
not
.
toHaveBeenCalled
();
expect
(
alert
.
exists
()).
toBe
(
true
);
expect
(
alert
.
text
()).
toContain
(
error
);
});
it
(
'
should clear the schedule form on a successful creation
'
,
()
=>
{
it
(
'
should clear the schedule form on a successful creation
'
,
()
=>
{
mutate
.
mockResolvedValueOnce
({});
mutate
.
mockImplementation
(()
=>
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
Promise
.
resolve
({
data
:
{
oncallScheduleCreate
:
{
errors
:
[]
}
}
}),
);
submitForm
();
expect
(
findModalForm
().
props
(
'
form
'
)).
toMatchObject
({
expect
(
findModalForm
().
props
(
'
form
'
)).
toMatchObject
({
name
:
''
,
name
:
''
,
description
:
''
,
description
:
''
,
...
@@ -194,10 +206,18 @@ describe('AddScheduleModal', () => {
...
@@ -194,10 +206,18 @@ describe('AddScheduleModal', () => {
});
});
});
});
describe
(
'
Schedule update apollo API call
'
,
()
=>
{
it
(
"
doesn't hide the modal on fail
"
,
async
()
=>
{
it
(
'
makes a request with `oncallScheduleUpdate` to update a schedule
'
,
()
=>
{
const
error
=
'
some error
'
;
mutate
.
mockResolvedValueOnce
({});
mutate
.
mockRejectedValueOnce
(
error
);
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
submitForm
();
await
waitForPromises
();
expect
(
mockHideModal
).
not
.
toHaveBeenCalled
();
});
it
(
'
makes a request with `oncallScheduleUpdate` to update a schedule and hides a modal on successful update
'
,
async
()
=>
{
mutate
.
mockResolvedValueOnce
({
data
:
{
oncallScheduleUpdate
:
{
errors
:
[]
}
}
});
submitForm
();
expect
(
mutate
).
toHaveBeenCalledWith
({
expect
(
mutate
).
toHaveBeenCalledWith
({
mutation
:
expect
.
any
(
Object
),
mutation
:
expect
.
any
(
Object
),
update
:
expect
.
anything
(),
update
:
expect
.
anything
(),
...
@@ -209,24 +229,10 @@ describe('AddScheduleModal', () => {
...
@@ -209,24 +229,10 @@ describe('AddScheduleModal', () => {
timezone
:
mockSchedule
.
timezone
.
identifier
,
timezone
:
mockSchedule
.
timezone
.
identifier
,
},
},
});
});
});
it
(
'
hides the modal on successful schedule creation
'
,
async
()
=>
{
mutate
.
mockResolvedValueOnce
({
data
:
{
oncallScheduleUpdate
:
{
errors
:
[]
}
}
});
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
await
waitForPromises
();
await
waitForPromises
();
expect
(
mockHideModal
).
toHaveBeenCalled
();
expect
(
mockHideModal
).
toHaveBeenCalled
();
});
});
it
(
"
doesn't hide the modal on fail
"
,
async
()
=>
{
const
error
=
'
some error
'
;
mutate
.
mockResolvedValueOnce
({
data
:
{
oncallScheduleUpdate
:
{
errors
:
[
error
]
}
}
});
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
});
await
waitForPromises
();
expect
(
mockHideModal
).
not
.
toHaveBeenCalled
();
});
});
describe
(
'
with mocked Apollo client
'
,
()
=>
{
describe
(
'
with mocked Apollo client
'
,
()
=>
{
it
(
'
calls a mutation with correct parameters and updates a schedule
'
,
async
()
=>
{
it
(
'
calls a mutation with correct parameters and updates a schedule
'
,
async
()
=>
{
createComponentWithApollo
();
createComponentWithApollo
();
...
@@ -255,7 +261,7 @@ describe('AddScheduleModal', () => {
...
@@ -255,7 +261,7 @@ describe('AddScheduleModal', () => {
it
(
'
it should not reload the page if the timezone has not changed
'
,
async
()
=>
{
it
(
'
it should not reload the page if the timezone has not changed
'
,
async
()
=>
{
mutate
.
mockResolvedValueOnce
({});
mutate
.
mockResolvedValueOnce
({});
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
}
);
submitForm
(
);
await
waitForPromises
();
await
waitForPromises
();
expect
(
window
.
location
.
reload
).
not
.
toHaveBeenCalled
();
expect
(
window
.
location
.
reload
).
not
.
toHaveBeenCalled
();
});
});
...
@@ -268,7 +274,7 @@ describe('AddScheduleModal', () => {
...
@@ -268,7 +274,7 @@ describe('AddScheduleModal', () => {
modalId
:
editScheduleModalId
,
modalId
:
editScheduleModalId
,
});
});
mutate
.
mockResolvedValueOnce
({});
mutate
.
mockResolvedValueOnce
({});
findModal
().
vm
.
$emit
(
'
primary
'
,
{
preventDefault
:
jest
.
fn
()
}
);
submitForm
(
);
expect
(
mutate
).
toHaveBeenCalledWith
({
expect
(
mutate
).
toHaveBeenCalledWith
({
mutation
:
updateOncallScheduleMutation
,
mutation
:
updateOncallScheduleMutation
,
update
:
expect
.
anything
(),
update
:
expect
.
anything
(),
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment