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
96a825cf
Commit
96a825cf
authored
Oct 09, 2020
by
David O'Regan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update from feedback
parent
55aa2d1f
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
32 additions
and
5 deletions
+32
-5
app/assets/javascripts/incidents/components/incidents_list.vue
...ssets/javascripts/incidents/components/incidents_list.vue
+9
-1
app/assets/javascripts/incidents/constants.js
app/assets/javascripts/incidents/constants.js
+9
-0
spec/frontend/incidents/components/incidents_list_spec.js
spec/frontend/incidents/components/incidents_list_spec.js
+14
-4
No files found.
app/assets/javascripts/incidents/components/incidents_list.vue
View file @
96a825cf
...
@@ -16,6 +16,7 @@ import {
...
@@ -16,6 +16,7 @@ import {
GlEmptyState
,
GlEmptyState
,
}
from
'
@gitlab/ui
'
;
}
from
'
@gitlab/ui
'
;
import
Api
from
'
~/api
'
;
import
Api
from
'
~/api
'
;
import
Tracking
from
'
~/tracking
'
;
import
TimeAgoTooltip
from
'
~/vue_shared/components/time_ago_tooltip.vue
'
;
import
TimeAgoTooltip
from
'
~/vue_shared/components/time_ago_tooltip.vue
'
;
import
FilteredSearchBar
from
'
~/vue_shared/components/filtered_search_bar/filtered_search_bar_root.vue
'
;
import
FilteredSearchBar
from
'
~/vue_shared/components/filtered_search_bar/filtered_search_bar_root.vue
'
;
import
AuthorToken
from
'
~/vue_shared/components/filtered_search_bar/tokens/author_token.vue
'
;
import
AuthorToken
from
'
~/vue_shared/components/filtered_search_bar/tokens/author_token.vue
'
;
...
@@ -41,6 +42,7 @@ import {
...
@@ -41,6 +42,7 @@ import {
TH_SEVERITY_TEST_ID
,
TH_SEVERITY_TEST_ID
,
TH_PUBLISHED_TEST_ID
,
TH_PUBLISHED_TEST_ID
,
INCIDENT_DETAILS_PATH
,
INCIDENT_DETAILS_PATH
,
trackIncidentCreateNewOptions
,
}
from
'
../constants
'
;
}
from
'
../constants
'
;
const
tdClass
=
const
tdClass
=
...
@@ -58,6 +60,7 @@ const initialPaginationState = {
...
@@ -58,6 +60,7 @@ const initialPaginationState = {
};
};
export
default
{
export
default
{
trackIncidentCreateNewOptions
,
i18n
:
I18N
,
i18n
:
I18N
,
statusTabs
:
INCIDENT_STATUS_TABS
,
statusTabs
:
INCIDENT_STATUS_TABS
,
fields
:
[
fields
:
[
...
@@ -335,6 +338,11 @@ export default {
...
@@ -335,6 +338,11 @@ export default {
navigateToIncidentDetails
({
iid
})
{
navigateToIncidentDetails
({
iid
})
{
return
visitUrl
(
joinPaths
(
this
.
issuePath
,
INCIDENT_DETAILS_PATH
,
iid
));
return
visitUrl
(
joinPaths
(
this
.
issuePath
,
INCIDENT_DETAILS_PATH
,
iid
));
},
},
navigateToCreateNewIncident
()
{
const
{
category
,
action
}
=
this
.
$options
.
trackIncidentCreateNewOptions
;
Tracking
.
event
(
category
,
action
);
this
.
redirecting
=
true
;
},
handlePageChange
(
page
)
{
handlePageChange
(
page
)
{
const
{
startCursor
,
endCursor
}
=
this
.
incidents
.
pageInfo
;
const
{
startCursor
,
endCursor
}
=
this
.
incidents
.
pageInfo
;
...
@@ -458,7 +466,7 @@ export default {
...
@@ -458,7 +466,7 @@ export default {
category=
"primary"
category=
"primary"
variant=
"success"
variant=
"success"
:href=
"newIncidentPath"
:href=
"newIncidentPath"
@
click=
"
redirecting = true
"
@
click=
"
navigateToCreateNewIncident
"
>
>
{{ $options.i18n.createIncidentBtnLabel }}
{{ $options.i18n.createIncidentBtnLabel }}
</gl-button>
</gl-button>
...
...
app/assets/javascripts/incidents/constants.js
View file @
96a825cf
/* eslint-disable @gitlab/require-i18n-strings */
import
{
s__
,
__
}
from
'
~/locale
'
;
import
{
s__
,
__
}
from
'
~/locale
'
;
export
const
I18N
=
{
export
const
I18N
=
{
...
@@ -34,6 +35,14 @@ export const INCIDENT_STATUS_TABS = [
...
@@ -34,6 +35,14 @@ export const INCIDENT_STATUS_TABS = [
},
},
];
];
/**
* Tracks snowplow event when user clicks create new incident
*/
export
const
trackIncidentCreateNewOptions
=
{
category
:
'
Incident Management
'
,
action
:
'
create_incident_button_clicks
'
,
};
export
const
DEFAULT_PAGE_SIZE
=
20
;
export
const
DEFAULT_PAGE_SIZE
=
20
;
export
const
TH_CREATED_AT_TEST_ID
=
{
'
data-testid
'
:
'
incident-management-created-at-sort
'
};
export
const
TH_CREATED_AT_TEST_ID
=
{
'
data-testid
'
:
'
incident-management-created-at-sort
'
};
export
const
TH_SEVERITY_TEST_ID
=
{
'
data-testid
'
:
'
incident-management-severity-sort
'
};
export
const
TH_SEVERITY_TEST_ID
=
{
'
data-testid
'
:
'
incident-management-severity-sort
'
};
...
...
spec/frontend/incidents/components/incidents_list_spec.js
View file @
96a825cf
...
@@ -10,6 +10,7 @@ import {
...
@@ -10,6 +10,7 @@ import {
GlBadge
,
GlBadge
,
GlEmptyState
,
GlEmptyState
,
}
from
'
@gitlab/ui
'
;
}
from
'
@gitlab/ui
'
;
import
Tracking
from
'
~/tracking
'
;
import
{
visitUrl
,
joinPaths
,
mergeUrlParams
}
from
'
~/lib/utils/url_utility
'
;
import
{
visitUrl
,
joinPaths
,
mergeUrlParams
}
from
'
~/lib/utils/url_utility
'
;
import
IncidentsList
from
'
~/incidents/components/incidents_list.vue
'
;
import
IncidentsList
from
'
~/incidents/components/incidents_list.vue
'
;
import
SeverityToken
from
'
~/sidebar/components/severity/severity.vue
'
;
import
SeverityToken
from
'
~/sidebar/components/severity/severity.vue
'
;
...
@@ -22,6 +23,7 @@ import {
...
@@ -22,6 +23,7 @@ import {
TH_CREATED_AT_TEST_ID
,
TH_CREATED_AT_TEST_ID
,
TH_SEVERITY_TEST_ID
,
TH_SEVERITY_TEST_ID
,
TH_PUBLISHED_TEST_ID
,
TH_PUBLISHED_TEST_ID
,
trackIncidentCreateNewOptions
,
}
from
'
~/incidents/constants
'
;
}
from
'
~/incidents/constants
'
;
import
mockIncidents
from
'
../mocks/incidents.json
'
;
import
mockIncidents
from
'
../mocks/incidents.json
'
;
import
mockFilters
from
'
../mocks/incidents_filter.json
'
;
import
mockFilters
from
'
../mocks/incidents_filter.json
'
;
...
@@ -33,6 +35,7 @@ jest.mock('~/lib/utils/url_utility', () => ({
...
@@ -33,6 +35,7 @@ jest.mock('~/lib/utils/url_utility', () => ({
setUrlParams
:
jest
.
fn
(),
setUrlParams
:
jest
.
fn
(),
updateHistory
:
jest
.
fn
(),
updateHistory
:
jest
.
fn
(),
}));
}));
jest
.
mock
(
'
~/tracking
'
);
describe
(
'
Incidents List
'
,
()
=>
{
describe
(
'
Incidents List
'
,
()
=>
{
let
wrapper
;
let
wrapper
;
...
@@ -52,7 +55,7 @@ describe('Incidents List', () => {
...
@@ -52,7 +55,7 @@ describe('Incidents List', () => {
const
findLoader
=
()
=>
wrapper
.
find
(
GlLoadingIcon
);
const
findLoader
=
()
=>
wrapper
.
find
(
GlLoadingIcon
);
const
findTimeAgo
=
()
=>
wrapper
.
findAll
(
TimeAgoTooltip
);
const
findTimeAgo
=
()
=>
wrapper
.
findAll
(
TimeAgoTooltip
);
const
findSearch
=
()
=>
wrapper
.
find
(
FilteredSearchBar
);
const
findSearch
=
()
=>
wrapper
.
find
(
FilteredSearchBar
);
const
findAssi
ng
ees
=
()
=>
wrapper
.
findAll
(
'
[data-testid="incident-assignees"]
'
);
const
findAssi
gn
ees
=
()
=>
wrapper
.
findAll
(
'
[data-testid="incident-assignees"]
'
);
const
findCreateIncidentBtn
=
()
=>
wrapper
.
find
(
'
[data-testid="createIncidentBtn"]
'
);
const
findCreateIncidentBtn
=
()
=>
wrapper
.
find
(
'
[data-testid="createIncidentBtn"]
'
);
const
findClosedIcon
=
()
=>
wrapper
.
findAll
(
"
[data-testid='incident-closed']
"
);
const
findClosedIcon
=
()
=>
wrapper
.
findAll
(
"
[data-testid='incident-closed']
"
);
const
findPagination
=
()
=>
wrapper
.
find
(
GlPagination
);
const
findPagination
=
()
=>
wrapper
.
find
(
GlPagination
);
...
@@ -164,14 +167,14 @@ describe('Incidents List', () => {
...
@@ -164,14 +167,14 @@ describe('Incidents List', () => {
describe
(
'
Assignees
'
,
()
=>
{
describe
(
'
Assignees
'
,
()
=>
{
it
(
'
shows Unassigned when there are no assignees
'
,
()
=>
{
it
(
'
shows Unassigned when there are no assignees
'
,
()
=>
{
expect
(
expect
(
findAssi
ng
ees
()
findAssi
gn
ees
()
.
at
(
0
)
.
at
(
0
)
.
text
(),
.
text
(),
).
toBe
(
I18N
.
unassigned
);
).
toBe
(
I18N
.
unassigned
);
});
});
it
(
'
renders an avatar component when there is an assignee
'
,
()
=>
{
it
(
'
renders an avatar component when there is an assignee
'
,
()
=>
{
const
avatar
=
findAssi
ng
ees
()
const
avatar
=
findAssi
gn
ees
()
.
at
(
1
)
.
at
(
1
)
.
find
(
GlAvatar
);
.
find
(
GlAvatar
);
const
{
src
,
label
}
=
avatar
.
attributes
();
const
{
src
,
label
}
=
avatar
.
attributes
();
...
@@ -211,7 +214,7 @@ describe('Incidents List', () => {
...
@@ -211,7 +214,7 @@ describe('Incidents List', () => {
});
});
});
});
it
(
'
shows the button linking to new incidents page with prefilled incident template when clicked
'
,
()
=>
{
it
(
'
shows the button linking to new incidents page with pre
-
filled incident template when clicked
'
,
()
=>
{
expect
(
findCreateIncidentBtn
().
exists
()).
toBe
(
true
);
expect
(
findCreateIncidentBtn
().
exists
()).
toBe
(
true
);
findCreateIncidentBtn
().
trigger
(
'
click
'
);
findCreateIncidentBtn
().
trigger
(
'
click
'
);
expect
(
mergeUrlParams
).
toHaveBeenCalledWith
(
expect
(
mergeUrlParams
).
toHaveBeenCalledWith
(
...
@@ -233,6 +236,13 @@ describe('Incidents List', () => {
...
@@ -233,6 +236,13 @@ describe('Incidents List', () => {
});
});
expect
(
findCreateIncidentBtn
().
exists
()).
toBe
(
false
);
expect
(
findCreateIncidentBtn
().
exists
()).
toBe
(
false
);
});
});
it
(
'
should track alert list page views
'
,
async
()
=>
{
findCreateIncidentBtn
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$nextTick
();
const
{
category
,
action
}
=
trackIncidentCreateNewOptions
;
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
category
,
action
);
});
});
});
describe
(
'
Pagination
'
,
()
=>
{
describe
(
'
Pagination
'
,
()
=>
{
...
...
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