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
7589e8ab
Commit
7589e8ab
authored
Aug 31, 2020
by
Simon Knox
Committed by
Jarka Košanová
Aug 31, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update URL when editing iteration
Quick n simple way, to be replaced with vue-router later
parent
ecf1a375
Changes
15
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
390 additions
and
43 deletions
+390
-43
ee/app/assets/javascripts/iterations/components/iteration_form.vue
...sets/javascripts/iterations/components/iteration_form.vue
+1
-1
ee/app/assets/javascripts/iterations/components/iteration_report.vue
...ts/javascripts/iterations/components/iteration_report.vue
+42
-5
ee/app/assets/javascripts/iterations/index.js
ee/app/assets/javascripts/iterations/index.js
+2
-1
ee/app/assets/javascripts/pages/groups/iterations/edit/index.js
.../assets/javascripts/pages/groups/iterations/edit/index.js
+6
-0
ee/app/assets/javascripts/pages/groups/iterations/show/index.js
.../assets/javascripts/pages/groups/iterations/show/index.js
+1
-1
ee/app/assets/javascripts/pages/projects/iterations/inherited/show/index.js
...scripts/pages/projects/iterations/inherited/show/index.js
+1
-1
ee/app/controllers/groups/iterations_controller.rb
ee/app/controllers/groups/iterations_controller.rb
+3
-1
ee/app/views/groups/iterations/edit.html.haml
ee/app/views/groups/iterations/edit.html.haml
+10
-0
ee/app/views/groups/iterations/show.html.haml
ee/app/views/groups/iterations/show.html.haml
+4
-1
ee/changelogs/unreleased/psi-iteration-edit.yml
ee/changelogs/unreleased/psi-iteration-edit.yml
+5
-0
ee/config/routes/group.rb
ee/config/routes/group.rb
+1
-1
ee/spec/controllers/groups/iterations_controller_spec.rb
ee/spec/controllers/groups/iterations_controller_spec.rb
+77
-0
ee/spec/controllers/projects/iterations_controller_spec.rb
ee/spec/controllers/projects/iterations_controller_spec.rb
+1
-1
ee/spec/features/groups/iterations/user_edits_iteration_spec.rb
...c/features/groups/iterations/user_edits_iteration_spec.rb
+111
-0
ee/spec/frontend/iterations/components/iteration_report_spec.js
...c/frontend/iterations/components/iteration_report_spec.js
+125
-30
No files found.
ee/app/assets/javascripts/iterations/components/iteration_form.vue
View file @
7589e8ab
...
@@ -210,7 +210,7 @@ export default {
...
@@ -210,7 +210,7 @@ export default {
</div>
</div>
<div
class=
"form-group row"
>
<div
class=
"form-group row"
>
<div
class=
"col-form-label col-sm-2"
>
<div
class=
"col-form-label col-sm-2"
>
<label
for=
"iteration-due-date"
>
{{ __('Due
D
ate') }}
</label>
<label
for=
"iteration-due-date"
>
{{ __('Due
d
ate') }}
</label>
</div>
</div>
<div
class=
"col-sm-10"
>
<div
class=
"col-sm-10"
>
<gl-form-input
<gl-form-input
...
...
ee/app/assets/javascripts/iterations/components/iteration_report.vue
View file @
7589e8ab
...
@@ -23,6 +23,11 @@ const iterationStates = {
...
@@ -23,6 +23,11 @@ const iterationStates = {
expired
:
'
expired
'
,
expired
:
'
expired
'
,
};
};
const
page
=
{
view
:
'
viewIteration
'
,
edit
:
'
editIteration
'
,
};
export
default
{
export
default
{
components
:
{
components
:
{
GlAlert
,
GlAlert
,
...
@@ -76,6 +81,11 @@ export default {
...
@@ -76,6 +81,11 @@ export default {
required
:
false
,
required
:
false
,
default
:
false
,
default
:
false
,
},
},
initiallyEditing
:
{
type
:
Boolean
,
required
:
false
,
default
:
false
,
},
namespaceType
:
{
namespaceType
:
{
type
:
String
,
type
:
String
,
required
:
false
,
required
:
false
,
...
@@ -90,7 +100,7 @@ export default {
...
@@ -90,7 +100,7 @@ export default {
},
},
data
()
{
data
()
{
return
{
return
{
isEditing
:
false
,
isEditing
:
this
.
initiallyEditing
,
error
:
''
,
error
:
''
,
iteration
:
{},
iteration
:
{},
};
};
...
@@ -118,10 +128,36 @@ export default {
...
@@ -118,10 +128,36 @@ export default {
}
}
},
},
},
},
mounted
()
{
this
.
boundOnPopState
=
this
.
onPopState
.
bind
(
this
);
window
.
addEventListener
(
'
popstate
'
,
this
.
boundOnPopState
);
},
beforeDestroy
()
{
window
.
removeEventListener
(
'
popstate
'
,
this
.
boundOnPopState
);
},
methods
:
{
methods
:
{
onPopState
(
e
)
{
if
(
e
.
state
?.
prev
===
page
.
view
)
{
this
.
isEditing
=
true
;
}
else
if
(
e
.
state
?.
prev
===
page
.
edit
)
{
this
.
isEditing
=
false
;
}
else
{
this
.
isEditing
=
this
.
initiallyEditing
;
}
},
formatDate
(
date
)
{
formatDate
(
date
)
{
return
formatDate
(
date
,
'
mmm d, yyyy
'
,
true
);
return
formatDate
(
date
,
'
mmm d, yyyy
'
,
true
);
},
},
loadEditPage
()
{
this
.
isEditing
=
true
;
const
newUrl
=
window
.
location
.
pathname
.
replace
(
/
(\/
edit
)?\/?
$/
,
'
/edit
'
);
window
.
history
.
pushState
({
prev
:
page
.
view
},
null
,
newUrl
);
},
loadReportPage
()
{
this
.
isEditing
=
false
;
const
newUrl
=
window
.
location
.
pathname
.
replace
(
/
\/
edit$/
,
''
);
window
.
history
.
pushState
({
prev
:
page
.
edit
},
null
,
newUrl
);
},
},
},
};
};
</
script
>
</
script
>
...
@@ -140,11 +176,11 @@ export default {
...
@@ -140,11 +176,11 @@ export default {
<iteration-form
<iteration-form
v-else-if=
"isEditing"
v-else-if=
"isEditing"
:group-path=
"fullPath"
:group-path=
"fullPath"
:preview-markdown-path=
"previewMarkdownPath"
:is-editing=
"true"
:is-editing=
"true"
:iteration=
"iteration"
:iteration=
"iteration"
:preview-markdown-path=
"previewMarkdownPath"
@
updated=
"loadReportPage"
@
updated=
"isEditing = false"
@
cancel=
"loadReportPage"
@
cancel=
"isEditing = false"
/>
/>
<template
v-else
>
<template
v-else
>
<div
<div
...
@@ -159,6 +195,7 @@ export default {
...
@@ -159,6 +195,7 @@ export default {
>
>
<gl-new-dropdown
<gl-new-dropdown
v-if=
"canEditIteration"
v-if=
"canEditIteration"
data-testid=
"actions-dropdown"
variant=
"default"
variant=
"default"
toggle-class=
"gl-text-decoration-none gl-border-0! gl-shadow-none!"
toggle-class=
"gl-text-decoration-none gl-border-0! gl-shadow-none!"
class=
"gl-ml-auto gl-text-secondary"
class=
"gl-ml-auto gl-text-secondary"
...
@@ -168,7 +205,7 @@ export default {
...
@@ -168,7 +205,7 @@ export default {
<template
#button-content
>
<template
#button-content
>
<gl-icon
name=
"ellipsis_v"
/><span
class=
"gl-sr-only"
>
{{
__
(
'
Actions
'
)
}}
</span>
<gl-icon
name=
"ellipsis_v"
/><span
class=
"gl-sr-only"
>
{{
__
(
'
Actions
'
)
}}
</span>
</
template
>
</
template
>
<gl-new-dropdown-item
@
click=
"
isEditing = tru
e"
>
{{
<gl-new-dropdown-item
@
click=
"
loadEditPag
e"
>
{{
__('Edit iteration')
__('Edit iteration')
}}
</gl-new-dropdown-item>
}}
</gl-new-dropdown-item>
</gl-new-dropdown>
</gl-new-dropdown>
...
...
ee/app/assets/javascripts/iterations/index.js
View file @
7589e8ab
...
@@ -49,7 +49,7 @@ export function initIterationForm() {
...
@@ -49,7 +49,7 @@ export function initIterationForm() {
});
});
}
}
export
function
initIterationReport
(
namespaceType
)
{
export
function
initIterationReport
(
{
namespaceType
,
initiallyEditing
}
=
{}
)
{
const
el
=
document
.
querySelector
(
'
.js-iteration
'
);
const
el
=
document
.
querySelector
(
'
.js-iteration
'
);
const
{
const
{
...
@@ -74,6 +74,7 @@ export function initIterationReport(namespaceType) {
...
@@ -74,6 +74,7 @@ export function initIterationReport(namespaceType) {
editIterationPath
,
editIterationPath
,
namespaceType
,
namespaceType
,
previewMarkdownPath
,
previewMarkdownPath
,
initiallyEditing
,
},
},
});
});
},
},
...
...
ee/app/assets/javascripts/pages/groups/iterations/edit/index.js
0 → 100644
View file @
7589e8ab
import
{
initIterationReport
}
from
'
ee/iterations
'
;
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
initIterationReport
({
namespaceType
:
Namespace
.
Group
,
initiallyEditing
:
true
});
});
ee/app/assets/javascripts/pages/groups/iterations/show/index.js
View file @
7589e8ab
...
@@ -2,5 +2,5 @@ import { initIterationReport } from 'ee/iterations';
...
@@ -2,5 +2,5 @@ import { initIterationReport } from 'ee/iterations';
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
initIterationReport
(
Namespace
.
Group
);
initIterationReport
(
{
namespaceType
:
Namespace
.
Group
}
);
});
});
ee/app/assets/javascripts/pages/projects/iterations/inherited/show/index.js
View file @
7589e8ab
...
@@ -2,5 +2,5 @@ import { initIterationReport } from 'ee/iterations';
...
@@ -2,5 +2,5 @@ import { initIterationReport } from 'ee/iterations';
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
initIterationReport
(
Namespace
.
Project
);
initIterationReport
(
{
namespaceType
:
Namespace
.
Project
}
);
});
});
ee/app/controllers/groups/iterations_controller.rb
View file @
7589e8ab
...
@@ -3,7 +3,7 @@
...
@@ -3,7 +3,7 @@
class
Groups::IterationsController
<
Groups
::
ApplicationController
class
Groups::IterationsController
<
Groups
::
ApplicationController
before_action
:check_iterations_available!
before_action
:check_iterations_available!
before_action
:authorize_show_iteration!
,
only:
[
:index
,
:show
]
before_action
:authorize_show_iteration!
,
only:
[
:index
,
:show
]
before_action
:authorize_create_iteration!
,
only:
:new
before_action
:authorize_create_iteration!
,
only:
[
:new
,
:edit
]
def
index
;
end
def
index
;
end
...
@@ -11,6 +11,8 @@ class Groups::IterationsController < Groups::ApplicationController
...
@@ -11,6 +11,8 @@ class Groups::IterationsController < Groups::ApplicationController
def
new
;
end
def
new
;
end
def
edit
;
end
private
private
def
check_iterations_available!
def
check_iterations_available!
...
...
ee/app/views/groups/iterations/edit.html.haml
0 → 100644
View file @
7589e8ab
-
add_to_breadcrumbs
_
(
"Iterations"
),
group_iterations_path
(
@group
)
-
breadcrumb_title
params
[
:id
]
-
page_title
_
(
"Edit iteration"
)
-
if
Feature
.
enabled?
(
:group_iterations
,
@group
,
default_enabled:
true
)
.js-iteration
{
data:
{
full_path:
@group
.
full_path
,
can_edit:
can?
(
current_user
,
:admin_iteration
,
@group
).
to_s
,
iteration_iid:
params
[
:id
],
preview_markdown_path:
preview_markdown_path
(
@group
)
}
}
ee/app/views/groups/iterations/show.html.haml
View file @
7589e8ab
...
@@ -3,4 +3,7 @@
...
@@ -3,4 +3,7 @@
-
page_title
_
(
"Iterations"
)
-
page_title
_
(
"Iterations"
)
-
if
Feature
.
enabled?
(
:group_iterations
,
@group
,
default_enabled:
true
)
-
if
Feature
.
enabled?
(
:group_iterations
,
@group
,
default_enabled:
true
)
.js-iteration
{
data:
{
full_path:
@group
.
full_path
,
iteration_iid:
params
[
:id
],
can_edit:
can?
(
current_user
,
:admin_iteration
,
@group
).
to_s
,
preview_markdown_path:
preview_markdown_path
(
@group
)
}
}
.js-iteration
{
data:
{
full_path:
@group
.
full_path
,
can_edit:
can?
(
current_user
,
:admin_iteration
,
@group
).
to_s
,
iteration_iid:
params
[
:id
],
preview_markdown_path:
preview_markdown_path
(
@group
)
}
}
ee/changelogs/unreleased/psi-iteration-edit.yml
0 → 100644
View file @
7589e8ab
---
title
:
Update URL when editing iteration
merge_request
:
39296
author
:
type
:
changed
ee/config/routes/group.rb
View file @
7589e8ab
...
@@ -124,7 +124,7 @@ constraints(::Constraints::GroupUrlConstrainer.new) do
...
@@ -124,7 +124,7 @@ constraints(::Constraints::GroupUrlConstrainer.new) do
end
end
end
end
resources
:iterations
,
only:
[
:index
,
:new
,
:show
],
constraints:
{
id:
/\d+/
}
resources
:iterations
,
only:
[
:index
,
:new
,
:
edit
,
:
show
],
constraints:
{
id:
/\d+/
}
resources
:issues
,
only:
[]
do
resources
:issues
,
only:
[]
do
collection
do
collection
do
...
...
ee/spec/controllers/groups/iterations_controller_spec.rb
0 → 100644
View file @
7589e8ab
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
Groups
::
IterationsController
do
using
RSpec
::
Parameterized
::
TableSyntax
let_it_be
(
:group
)
{
create
(
:group
,
:private
)
}
let_it_be
(
:iteration
)
{
create
(
:iteration
,
group:
group
)
}
let_it_be
(
:user
)
{
create
(
:user
)
}
before
do
stub_licensed_features
(
iterations:
iteration_license_available
)
group
.
send
(
"add_
#{
role
}
"
,
user
)
unless
role
==
:none
sign_in
(
user
)
end
describe
'index'
do
subject
{
get
:index
,
params:
{
group_id:
group
}
}
where
(
:iteration_license_available
,
:role
,
:status
)
do
false
|
:developer
|
:not_found
true
|
:none
|
:not_found
true
|
:guest
|
:success
true
|
:developer
|
:success
end
with_them
do
it_behaves_like
'returning response status'
,
params
[
:status
]
end
end
describe
'show'
do
subject
{
get
:show
,
params:
{
group_id:
group
,
id:
iteration
}
}
where
(
:iteration_license_available
,
:role
,
:status
)
do
false
|
:developer
|
:not_found
true
|
:none
|
:not_found
true
|
:guest
|
:success
true
|
:developer
|
:success
end
with_them
do
it_behaves_like
'returning response status'
,
params
[
:status
]
end
end
describe
'new'
do
subject
{
get
:new
,
params:
{
group_id:
group
}
}
where
(
:iteration_license_available
,
:role
,
:status
)
do
false
|
:developer
|
:not_found
true
|
:none
|
:not_found
true
|
:guest
|
:not_found
true
|
:developer
|
:success
end
with_them
do
it_behaves_like
'returning response status'
,
params
[
:status
]
end
end
describe
'edit'
do
subject
{
get
:edit
,
params:
{
group_id:
group
,
id:
iteration
}
}
where
(
:iteration_license_available
,
:role
,
:status
)
do
false
|
:developer
|
:not_found
true
|
:none
|
:not_found
true
|
:guest
|
:not_found
true
|
:developer
|
:success
end
with_them
do
it_behaves_like
'returning response status'
,
params
[
:status
]
end
end
end
ee/spec/controllers/projects/iterations_controller_spec.rb
View file @
7589e8ab
...
@@ -6,7 +6,7 @@ RSpec.describe Projects::IterationsController do
...
@@ -6,7 +6,7 @@ RSpec.describe Projects::IterationsController do
let_it_be
(
:project
)
{
create
(
:project
)
}
let_it_be
(
:project
)
{
create
(
:project
)
}
let_it_be
(
:user
)
{
create
(
:user
)
}
let_it_be
(
:user
)
{
create
(
:user
)
}
context
'index'
do
describe
'index'
do
context
'when iterations license is not available'
do
context
'when iterations license is not available'
do
before
do
before
do
stub_licensed_features
(
iterations:
false
)
stub_licensed_features
(
iterations:
false
)
...
...
ee/spec/features/groups/iterations/user_edits_iteration_spec.rb
0 → 100644
View file @
7589e8ab
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
'User views iteration'
do
let_it_be
(
:now
)
{
Time
.
now
}
let_it_be
(
:group
)
{
create
(
:group
)
}
let_it_be
(
:user
)
{
create
(
:group_member
,
:maintainer
,
user:
create
(
:user
),
group:
group
).
user
}
let_it_be
(
:guest_user
)
{
create
(
:group_member
,
:guest
,
user:
create
(
:user
),
group:
group
).
user
}
let_it_be
(
:iteration
)
{
create
(
:iteration
,
:skip_future_date_validation
,
iid:
1
,
id:
2
,
group:
group
,
title:
'Correct Iteration'
,
description:
'Iteration description'
,
start_date:
now
-
1
.
day
,
due_date:
now
)
}
dropdown_selector
=
'[data-testid="actions-dropdown"]'
context
'with license'
do
before
do
stub_licensed_features
(
iterations:
true
)
end
context
'as authorized user'
do
before
do
sign_in
(
user
)
end
context
'load edit page directly'
,
:js
do
before
do
visit
edit_group_iteration_path
(
group
,
iteration
)
end
it
'prefills fields and allows updating all values'
do
aggregate_failures
do
expect
(
title_input
.
value
).
to
eq
(
iteration
.
title
)
expect
(
description_input
.
value
).
to
eq
(
iteration
.
description
)
expect
(
start_date_input
.
value
).
to
have_content
(
iteration
.
start_date
)
expect
(
due_date_input
.
value
).
to
have_content
(
iteration
.
due_date
)
end
updated_title
=
'Updated iteration title'
updated_desc
=
'Updated iteration desc'
updated_start_date
=
now
+
4
.
days
updated_due_date
=
now
+
5
.
days
fill_in
(
'Title'
,
with:
updated_title
)
fill_in
(
'Description'
,
with:
updated_desc
)
fill_in
(
'Start date'
,
with:
updated_start_date
.
strftime
(
'%Y-%m-%d'
))
fill_in
(
'Due date'
,
with:
updated_due_date
.
strftime
(
'%Y-%m-%d'
))
click_button
(
'Update iteration'
)
aggregate_failures
do
expect
(
page
).
to
have_content
(
updated_title
)
expect
(
page
).
to
have_content
(
updated_start_date
.
strftime
(
'%b %-d, %Y'
))
expect
(
page
).
to
have_content
(
updated_due_date
.
strftime
(
'%b %-d, %Y'
))
expect
(
page
).
to
have_current_path
(
group_iteration_path
(
group
,
iteration
))
end
end
end
context
'load edit page from report'
,
:js
do
before
do
visit
group_iteration_path
(
iteration
.
group
,
iteration
)
end
it
'prefills fields and updates URL'
do
find
(
dropdown_selector
).
click
click_button
(
'Edit iteration'
)
aggregate_failures
do
expect
(
title_input
.
value
).
to
eq
(
iteration
.
title
)
expect
(
description_input
.
value
).
to
eq
(
iteration
.
description
)
expect
(
start_date_input
.
value
).
to
have_content
(
iteration
.
start_date
)
expect
(
due_date_input
.
value
).
to
have_content
(
iteration
.
due_date
)
expect
(
page
).
to
have_current_path
(
edit_group_iteration_path
(
iteration
.
group
,
iteration
))
end
end
end
end
context
'as guest user'
do
before
do
sign_in
(
guest_user
)
end
it
'does not show edit dropdown'
,
:js
do
visit
group_iteration_path
(
iteration
.
group
,
iteration
)
expect
(
page
).
to
have_content
(
iteration
.
title
)
expect
(
page
).
not_to
have_selector
(
dropdown_selector
)
end
it
'404s when loading edit page directly'
do
visit
edit_group_iteration_path
(
iteration
.
group
,
iteration
)
expect
(
page
).
to
have_gitlab_http_status
(
:not_found
)
end
end
def
title_input
page
.
find
(
'#iteration-title'
)
end
def
description_input
page
.
find
(
'#iteration-description'
)
end
def
start_date_input
page
.
find
(
'#iteration-start-date'
)
end
def
due_date_input
page
.
find
(
'#iteration-due-date'
)
end
end
end
ee/spec/frontend/iterations/components/iteration_report_spec.js
View file @
7589e8ab
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlNewDropdown
,
GlEmptyState
,
GlLoadingIcon
,
GlTab
,
GlTabs
}
from
'
@gitlab/ui
'
;
import
{
GlNewDropdown
,
GlNewDropdownItem
,
GlEmptyState
,
GlLoadingIcon
,
GlTab
,
GlTabs
,
}
from
'
@gitlab/ui
'
;
import
IterationReport
from
'
ee/iterations/components/iteration_report.vue
'
;
import
IterationReport
from
'
ee/iterations/components/iteration_report.vue
'
;
import
IterationForm
from
'
ee/iterations/components/iteration_form.vue
'
;
import
IterationReportSummary
from
'
ee/iterations/components/iteration_report_summary.vue
'
;
import
IterationReportSummary
from
'
ee/iterations/components/iteration_report_summary.vue
'
;
import
IterationReportTabs
from
'
ee/iterations/components/iteration_report_tabs.vue
'
;
import
IterationReportTabs
from
'
ee/iterations/components/iteration_report_tabs.vue
'
;
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
import
{
Namespace
}
from
'
ee/iterations/constants
'
;
...
@@ -15,6 +23,11 @@ describe('Iterations report', () => {
...
@@ -15,6 +23,11 @@ describe('Iterations report', () => {
const
findTopbar
=
()
=>
wrapper
.
find
({
ref
:
'
topbar
'
});
const
findTopbar
=
()
=>
wrapper
.
find
({
ref
:
'
topbar
'
});
const
findTitle
=
()
=>
wrapper
.
find
({
ref
:
'
title
'
});
const
findTitle
=
()
=>
wrapper
.
find
({
ref
:
'
title
'
});
const
findDescription
=
()
=>
wrapper
.
find
({
ref
:
'
description
'
});
const
findDescription
=
()
=>
wrapper
.
find
({
ref
:
'
description
'
});
const
findActionsDropdown
=
()
=>
wrapper
.
find
(
'
[data-testid="actions-dropdown"]
'
);
const
clickEditButton
=
()
=>
{
findActionsDropdown
().
vm
.
$emit
(
'
click
'
);
wrapper
.
find
(
GlNewDropdownItem
).
vm
.
$emit
(
'
click
'
);
};
const
mountComponent
=
({
props
=
defaultProps
,
loading
=
false
}
=
{})
=>
{
const
mountComponent
=
({
props
=
defaultProps
,
loading
=
false
}
=
{})
=>
{
wrapper
=
shallowMount
(
IterationReport
,
{
wrapper
=
shallowMount
(
IterationReport
,
{
...
@@ -55,6 +68,7 @@ describe('Iterations report', () => {
...
@@ -55,6 +68,7 @@ describe('Iterations report', () => {
expect
(
wrapper
.
find
(
GlEmptyState
).
props
(
'
title
'
)).
toEqual
(
'
Could not find iteration
'
);
expect
(
wrapper
.
find
(
GlEmptyState
).
props
(
'
title
'
)).
toEqual
(
'
Could not find iteration
'
);
expect
(
findTitle
().
exists
()).
toBe
(
false
);
expect
(
findTitle
().
exists
()).
toBe
(
false
);
expect
(
findDescription
().
exists
()).
toBe
(
false
);
expect
(
findDescription
().
exists
()).
toBe
(
false
);
expect
(
findActionsDropdown
().
exists
()).
toBe
(
false
);
});
});
});
});
...
@@ -67,46 +81,127 @@ describe('Iterations report', () => {
...
@@ -67,46 +81,127 @@ describe('Iterations report', () => {
dueDate
:
'
2020-06-08
'
,
dueDate
:
'
2020-06-08
'
,
};
};
beforeEach
(()
=>
{
describe
(
'
user without edit permission
'
,
()
=>
{
mountComponent
({
beforeEach
(()
=>
{
loading
:
false
,
mountComponent
({
loading
:
false
,
});
wrapper
.
setData
({
iteration
,
});
});
});
wrapper
.
setData
({
it
(
'
shows status and date in header
'
,
()
=>
{
iteration
,
expect
(
findTopbar
().
text
()).
toContain
(
'
Open
'
);
expect
(
findTopbar
().
text
()).
toContain
(
'
Jun 2, 2020
'
);
expect
(
findTopbar
().
text
()).
toContain
(
'
Jun 8, 2020
'
);
});
});
});
it
(
'
shows status and date in header
'
,
()
=>
{
it
(
'
hides empty region and loading spinner
'
,
()
=>
{
expect
(
findTopbar
().
text
()).
toContain
(
'
Open
'
);
expect
(
wrapper
.
find
(
GlLoadingIcon
).
exists
()).
toBe
(
false
);
expect
(
findTopbar
().
text
()).
toContain
(
'
Jun 2, 2020
'
);
expect
(
wrapper
.
find
(
GlEmptyState
).
exists
()).
toBe
(
false
);
expect
(
findTopbar
().
text
()).
toContain
(
'
Jun 8, 2020
'
);
});
});
it
(
'
hides empty region and loading spinner
'
,
()
=>
{
it
(
'
shows title and description
'
,
()
=>
{
expect
(
wrapper
.
find
(
GlLoadingIcon
).
exists
()).
toBe
(
fals
e
);
expect
(
findTitle
().
text
()).
toContain
(
iteration
.
titl
e
);
expect
(
wrapper
.
find
(
GlEmptyState
).
exists
()).
toBe
(
false
);
expect
(
findDescription
().
text
()).
toContain
(
iteration
.
descriptionHtml
);
});
});
it
(
'
shows title and descriptio
n
'
,
()
=>
{
it
(
'
hides actions dropdow
n
'
,
()
=>
{
expect
(
findTitle
().
text
()).
toContain
(
iteration
.
titl
e
);
expect
(
findActionsDropdown
().
exists
()).
toBe
(
fals
e
);
expect
(
findDescription
().
text
()).
toContain
(
iteration
.
descriptionHtml
);
}
);
});
});
it
(
'
passes correct props to IterationReportSummary
'
,
()
=>
{
describe
(
'
user with edit permission
'
,
()
=>
{
const
iterationReportSummary
=
wrapper
.
find
(
IterationReportSummary
);
describe
(
'
loading report view
'
,
()
=>
{
beforeEach
(()
=>
{
mountComponent
({
props
:
{
...
defaultProps
,
canEdit
:
true
,
},
loading
:
false
,
});
expect
(
iterationReportSummary
.
props
(
'
fullPath
'
)).
toBe
(
defaultProps
.
fullPath
);
wrapper
.
setData
({
expect
(
iterationReportSummary
.
props
(
'
iterationId
'
)).
toBe
(
iteration
.
id
);
iteration
,
expect
(
iterationReportSummary
.
props
(
'
namespaceType
'
)).
toBe
(
Namespace
.
Group
);
});
});
});
it
(
'
updates URL when loading form
'
,
async
()
=>
{
jest
.
spyOn
(
window
.
history
,
'
pushState
'
).
mockImplementation
(()
=>
{});
clickEditButton
();
await
wrapper
.
vm
.
$nextTick
();
it
(
'
passes correct props to IterationReportTabs
'
,
()
=>
{
expect
(
window
.
history
.
pushState
).
toHaveBeenCalledWith
(
const
iterationReportTabs
=
wrapper
.
find
(
IterationReportTabs
);
{
prev
:
'
viewIteration
'
},
null
,
'
/edit
'
,
);
});
expect
(
iterationReportTabs
.
props
(
'
fullPath
'
)).
toBe
(
defaultProps
.
fullPath
);
it
(
'
passes correct props to IterationReportSummary
'
,
()
=>
{
expect
(
iterationReportTabs
.
props
(
'
iterationId
'
)).
toBe
(
iteration
.
id
);
const
iterationReportSummary
=
wrapper
.
find
(
IterationReportSummary
);
expect
(
iterationReportTabs
.
props
(
'
namespaceType
'
)).
toBe
(
Namespace
.
Group
);
expect
(
iterationReportSummary
.
props
(
'
fullPath
'
)).
toBe
(
defaultProps
.
fullPath
);
expect
(
iterationReportSummary
.
props
(
'
iterationId
'
)).
toBe
(
iteration
.
id
);
expect
(
iterationReportSummary
.
props
(
'
namespaceType
'
)).
toBe
(
Namespace
.
Group
);
});
it
(
'
passes correct props to IterationReportTabs
'
,
()
=>
{
const
iterationReportTabs
=
wrapper
.
find
(
IterationReportTabs
);
expect
(
iterationReportTabs
.
props
(
'
fullPath
'
)).
toBe
(
defaultProps
.
fullPath
);
expect
(
iterationReportTabs
.
props
(
'
iterationId
'
)).
toBe
(
iteration
.
id
);
expect
(
iterationReportTabs
.
props
(
'
namespaceType
'
)).
toBe
(
Namespace
.
Group
);
});
});
describe
(
'
loading edit form directly
'
,
()
=>
{
beforeEach
(()
=>
{
mountComponent
({
props
:
{
...
defaultProps
,
canEdit
:
true
,
initiallyEditing
:
true
,
},
loading
:
false
,
});
wrapper
.
setData
({
iteration
,
});
});
it
(
'
updates URL when cancelling form submit
'
,
async
()
=>
{
jest
.
spyOn
(
window
.
history
,
'
pushState
'
).
mockImplementation
(()
=>
{});
wrapper
.
find
(
IterationForm
).
vm
.
$emit
(
'
cancel
'
);
await
wrapper
.
vm
.
$nextTick
();
expect
(
window
.
history
.
pushState
).
toHaveBeenCalledWith
(
{
prev
:
'
editIteration
'
},
null
,
'
/
'
,
);
});
it
(
'
updates URL after form submitted
'
,
async
()
=>
{
jest
.
spyOn
(
window
.
history
,
'
pushState
'
).
mockImplementation
(()
=>
{});
wrapper
.
find
(
IterationForm
).
vm
.
$emit
(
'
updated
'
);
await
wrapper
.
vm
.
$nextTick
();
expect
(
window
.
history
.
pushState
).
toHaveBeenCalledWith
(
{
prev
:
'
editIteration
'
},
null
,
'
/
'
,
);
});
});
});
});
describe
(
'
actions dropdown to edit iteration
'
,
()
=>
{
describe
(
'
actions dropdown to edit iteration
'
,
()
=>
{
...
...
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