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
6979e878
Commit
6979e878
authored
Jan 24, 2022
by
Stanislav Lashmanov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor nextTick to use direct import from Vue package
RFC:
https://gitlab.com/gitlab-org/frontend/rfcs/-/issues/47
parent
79f66000
Changes
74
Hide whitespace changes
Inline
Side-by-side
Showing
74 changed files
with
534 additions
and
567 deletions
+534
-567
ee/spec/frontend/security_dashboard/components/group/group_security_dashboard_spec.js
...shboard/components/group/group_security_dashboard_spec.js
+2
-1
ee/spec/frontend/security_dashboard/components/group/group_vulnerabilities_spec.js
..._dashboard/components/group/group_vulnerabilities_spec.js
+4
-4
ee/spec/frontend/security_dashboard/components/instance/instance_security_dashboard_spec.js
...d/components/instance/instance_security_dashboard_spec.js
+2
-1
ee/spec/frontend/security_dashboard/components/instance/instance_vulnerabilities_spec.js
...oard/components/instance/instance_vulnerabilities_spec.js
+4
-4
ee/spec/frontend/security_dashboard/components/pipeline/filters_spec.js
...nd/security_dashboard/components/pipeline/filters_spec.js
+3
-3
ee/spec/frontend/security_dashboard/components/pipeline/security_reports_summary_spec.js
...oard/components/pipeline/security_reports_summary_spec.js
+3
-2
ee/spec/frontend/security_dashboard/components/pipeline/selection_summary_vuex_spec.js
...hboard/components/pipeline/selection_summary_vuex_spec.js
+2
-2
ee/spec/frontend/security_dashboard/components/project/project_security_dashboard_spec.js
...ard/components/project/project_security_dashboard_spec.js
+8
-8
ee/spec/frontend/security_dashboard/components/project/project_vulnerabilities_spec.js
...hboard/components/project/project_vulnerabilities_spec.js
+3
-2
ee/spec/frontend/security_dashboard/components/shared/csv_export_button_spec.js
...ity_dashboard/components/shared/csv_export_button_spec.js
+5
-4
ee/spec/frontend/security_dashboard/components/shared/filters/filter_body_spec.js
...y_dashboard/components/shared/filters/filter_body_spec.js
+3
-2
ee/spec/frontend/security_dashboard/components/shared/filters/scanner_filter_spec.js
...ashboard/components/shared/filters/scanner_filter_spec.js
+2
-2
ee/spec/frontend/security_dashboard/components/shared/filters/simple_filter_spec.js
...dashboard/components/shared/filters/simple_filter_spec.js
+5
-5
ee/spec/frontend/security_dashboard/components/shared/selection_summary_spec.js
...ity_dashboard/components/shared/selection_summary_spec.js
+4
-4
ee/spec/frontend/security_dashboard/components/shared/vulnerabilities_over_time_chart_spec.js
...components/shared/vulnerabilities_over_time_chart_spec.js
+3
-4
ee/spec/frontend/security_dashboard/components/shared/vulnerability_count_list_spec.js
...hboard/components/shared/vulnerability_count_list_spec.js
+3
-2
ee/spec/frontend/security_dashboard/components/shared/vulnerability_list_spec.js
...ty_dashboard/components/shared/vulnerability_list_spec.js
+8
-7
ee/spec/frontend/security_dashboard/components/shared/vulnerability_report/vulnerability_list_spec.js
...ts/shared/vulnerability_report/vulnerability_list_spec.js
+9
-8
ee/spec/frontend/sidebar/components/cve_id_request_spec.js
ee/spec/frontend/sidebar/components/cve_id_request_spec.js
+4
-3
ee/spec/frontend/sidebar/components/iteration_dropdown_spec.js
...ec/frontend/sidebar/components/iteration_dropdown_spec.js
+3
-3
ee/spec/frontend/sidebar/components/status/status_spec.js
ee/spec/frontend/sidebar/components/status/status_spec.js
+10
-10
ee/spec/frontend/sidebar/weight_spec.js
ee/spec/frontend/sidebar/weight_spec.js
+9
-8
ee/spec/frontend/subscriptions/buy_addons_shared/components/order_summary_spec.js
...ptions/buy_addons_shared/components/order_summary_spec.js
+2
-2
ee/spec/frontend/test_case_create/components/test_case_create_root_spec.js
...test_case_create/components/test_case_create_root_spec.js
+3
-2
ee/spec/frontend/test_case_list/components/test_case_list_empty_spec.js
...nd/test_case_list/components/test_case_list_empty_spec.js
+4
-3
ee/spec/frontend/test_case_show/components/test_case_show_root_spec.js
...end/test_case_show/components/test_case_show_root_spec.js
+7
-6
ee/spec/frontend/test_case_show/components/test_case_sidebar_spec.js
...ntend/test_case_show/components/test_case_sidebar_spec.js
+9
-8
ee/spec/frontend/threat_monitoring/components/alerts/alert_drawer_spec.js
.../threat_monitoring/components/alerts/alert_drawer_spec.js
+2
-1
ee/spec/frontend/threat_monitoring/components/alerts/alert_filters_spec.js
...threat_monitoring/components/alerts/alert_filters_spec.js
+2
-1
ee/spec/frontend/threat_monitoring/components/alerts/alert_status_spec.js
.../threat_monitoring/components/alerts/alert_status_spec.js
+3
-2
ee/spec/frontend/threat_monitoring/components/alerts/alerts_list_spec.js
...d/threat_monitoring/components/alerts/alerts_list_spec.js
+9
-8
ee/spec/frontend/threat_monitoring/components/instance_project_selector_spec.js
...t_monitoring/components/instance_project_selector_spec.js
+3
-3
ee/spec/frontend/threat_monitoring/components/policies/no_policies_empty_state_spec.js
...oring/components/policies/no_policies_empty_state_spec.js
+2
-1
ee/spec/frontend/threat_monitoring/components/policies/policies_app_spec.js
...hreat_monitoring/components/policies/policies_app_spec.js
+2
-1
ee/spec/frontend/threat_monitoring/components/policies/policies_header_spec.js
...at_monitoring/components/policies/policies_header_spec.js
+3
-2
ee/spec/frontend/threat_monitoring/components/policies/policies_list_spec.js
...reat_monitoring/components/policies/policies_list_spec.js
+5
-5
ee/spec/frontend/threat_monitoring/components/policies/scan_new_policy_modal_spec.js
...itoring/components/policies/scan_new_policy_modal_spec.js
+3
-3
ee/spec/frontend/threat_monitoring/components/policy_editor/network_policy/network_policy_editor_spec.js
...olicy_editor/network_policy/network_policy_editor_spec.js
+2
-1
ee/spec/frontend/threat_monitoring/components/policy_editor/network_policy/policy_rule_builder_spec.js
.../policy_editor/network_policy/policy_rule_builder_spec.js
+10
-9
ee/spec/frontend/threat_monitoring/components/policy_editor/policy_alert_picker_spec.js
...ring/components/policy_editor/policy_alert_picker_spec.js
+2
-2
ee/spec/frontend/threat_monitoring/components/policy_editor/policy_editor_spec.js
...monitoring/components/policy_editor/policy_editor_spec.js
+6
-5
ee/spec/frontend/threat_monitoring/components/policy_editor/scan_execution_policy/scan_execution_policy_editor_spec.js
...can_execution_policy/scan_execution_policy_editor_spec.js
+5
-4
ee/spec/frontend/threat_monitoring/components/policy_yaml_editor_spec.js
...d/threat_monitoring/components/policy_yaml_editor_spec.js
+2
-1
ee/spec/frontend/threat_monitoring/components/statistics_history_spec.js
...d/threat_monitoring/components/statistics_history_spec.js
+3
-3
ee/spec/frontend/trials/components/country_or_region_selector_spec.js
...tend/trials/components/country_or_region_selector_spec.js
+2
-2
ee/spec/frontend/usage_quotas/storage/components/collapsible_project_storage_detail_spec.js
...age/components/collapsible_project_storage_detail_spec.js
+7
-8
ee/spec/frontend/usage_quotas/storage/components/namespace_storage_app_spec.js
...e_quotas/storage/components/namespace_storage_app_spec.js
+8
-7
ee/spec/frontend/usage_quotas/storage/components/temporary_storage_increase_modal_spec.js
...orage/components/temporary_storage_increase_modal_spec.js
+3
-2
ee/spec/frontend/vue_mr_widget/components/approvals/approvals_footer_spec.js
...e_mr_widget/components/approvals/approvals_footer_spec.js
+7
-12
ee/spec/frontend/vue_mr_widget/components/approvals/approvals_spec.js
...tend/vue_mr_widget/components/approvals/approvals_spec.js
+59
-62
ee/spec/frontend/vue_mr_widget/components/merge_immediately_confirmation_dialog_spec.js
.../components/merge_immediately_confirmation_dialog_spec.js
+3
-2
ee/spec/frontend/vue_mr_widget/components/states/mr_widget_enable_feature_prompt_spec.js
...components/states/mr_widget_enable_feature_prompt_spec.js
+2
-1
ee/spec/frontend/vue_mr_widget/components/states/mr_widget_ready_to_merge_spec.js
...widget/components/states/mr_widget_ready_to_merge_spec.js
+19
-25
ee/spec/frontend/vue_mr_widget/ee_mr_widget_options_spec.js
ee/spec/frontend/vue_mr_widget/ee_mr_widget_options_spec.js
+35
-47
ee/spec/frontend/vue_shared/components/accordion/accordion_item_spec.js
...nd/vue_shared/components/accordion/accordion_item_spec.js
+12
-14
ee/spec/frontend/vue_shared/components/filtered_search_bar/tokens/epic_token_spec.js
.../components/filtered_search_bar/tokens/epic_token_spec.js
+4
-4
ee/spec/frontend/vue_shared/components/filtered_search_bar/tokens/iteration_token_spec.js
...onents/filtered_search_bar/tokens/iteration_token_spec.js
+2
-1
ee/spec/frontend/vue_shared/components/sidebar/epics_select/base_spec.js
...d/vue_shared/components/sidebar/epics_select/base_spec.js
+14
-13
ee/spec/frontend/vue_shared/components/sidebar/epics_select/dropdown_value_spec.js
...ed/components/sidebar/epics_select/dropdown_value_spec.js
+9
-10
ee/spec/frontend/vue_shared/license_compliance/components/delete_confirmation_modal_spec.js
...e_compliance/components/delete_confirmation_modal_spec.js
+3
-3
ee/spec/frontend/vue_shared/license_compliance/license_management_spec.js
.../vue_shared/license_compliance/license_management_spec.js
+9
-11
ee/spec/frontend/vue_shared/security_reports/components/dismiss_button_spec.js
...shared/security_reports/components/dismiss_button_spec.js
+10
-12
ee/spec/frontend/vue_shared/security_reports/components/dismissal_comment_box_spec.js
...security_reports/components/dismissal_comment_box_spec.js
+10
-12
ee/spec/frontend/vue_shared/security_reports/components/dismissal_comment_modal_footer_spec.js
...reports/components/dismissal_comment_modal_footer_spec.js
+19
-22
ee/spec/frontend/vue_shared/security_reports/components/event_item_spec.js
...vue_shared/security_reports/components/event_item_spec.js
+7
-11
ee/spec/frontend/vue_shared/security_reports/components/modal_footer_spec.js
...e_shared/security_reports/components/modal_footer_spec.js
+10
-12
ee/spec/frontend/vue_shared/security_reports/components/solution_card_spec.js
..._shared/security_reports/components/solution_card_spec.js
+3
-2
ee/spec/frontend/vue_shared/security_reports/components/solution_card_vuex_spec.js
...ed/security_reports/components/solution_card_vuex_spec.js
+6
-7
ee/spec/frontend/vue_shared/survey_banner/survey_banner_spec.js
...c/frontend/vue_shared/survey_banner/survey_banner_spec.js
+4
-3
ee/spec/frontend/vulnerabilities/header_spec.js
ee/spec/frontend/vulnerabilities/header_spec.js
+5
-6
ee/spec/frontend/vulnerabilities/history_comment_editor_spec.js
...c/frontend/vulnerabilities/history_comment_editor_spec.js
+2
-1
ee/spec/frontend/vulnerabilities/history_comment_spec.js
ee/spec/frontend/vulnerabilities/history_comment_spec.js
+29
-40
ee/spec/frontend/vulnerabilities/related_issues_spec.js
ee/spec/frontend/vulnerabilities/related_issues_spec.js
+6
-5
ee/spec/frontend/vulnerabilities/vulnerability_state_dropdown_spec.js
...tend/vulnerabilities/vulnerability_state_dropdown_spec.js
+37
-48
No files found.
ee/spec/frontend/security_dashboard/components/group/group_security_dashboard_spec.js
View file @
6979e878
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
GroupSecurityDashboard
from
'
ee/security_dashboard/components/group/group_security_dashboard.vue
'
;
import
GroupSecurityDashboard
from
'
ee/security_dashboard/components/group/group_security_dashboard.vue
'
;
import
ReportNotConfiguredGroup
from
'
ee/security_dashboard/components/shared/empty_states/report_not_configured_group.vue
'
;
import
ReportNotConfiguredGroup
from
'
ee/security_dashboard/components/shared/empty_states/report_not_configured_group.vue
'
;
import
VulnerabilitySeverities
from
'
ee/security_dashboard/components/shared/project_security_status_chart.vue
'
;
import
VulnerabilitySeverities
from
'
ee/security_dashboard/components/shared/project_security_status_chart.vue
'
;
...
@@ -93,7 +94,7 @@ describe('Group Security Dashboard component', () => {
...
@@ -93,7 +94,7 @@ describe('Group Security Dashboard component', () => {
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
projects
:
[{
name
:
'
project1
'
}]
});
wrapper
.
setData
({
projects
:
[{
name
:
'
project1
'
}]
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
securityChartsLayout
=
findSecurityChartsLayoutComponent
();
const
securityChartsLayout
=
findSecurityChartsLayoutComponent
();
const
reportNotConfigured
=
findReportNotConfigured
();
const
reportNotConfigured
=
findReportNotConfigured
();
...
...
ee/spec/frontend/security_dashboard/components/group/group_vulnerabilities_spec.js
View file @
6979e878
import
{
GlAlert
,
GlIntersectionObserver
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlAlert
,
GlIntersectionObserver
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
nextTick
}
from
'
vue
'
;
import
GroupVulnerabilities
from
'
ee/security_dashboard/components/group/group_vulnerabilities.vue
'
;
import
GroupVulnerabilities
from
'
ee/security_dashboard/components/group/group_vulnerabilities.vue
'
;
import
VulnerabilityList
from
'
ee/security_dashboard/components/shared/vulnerability_list.vue
'
;
import
VulnerabilityList
from
'
ee/security_dashboard/components/shared/vulnerability_list.vue
'
;
import
vulnerabilitiesQuery
from
'
ee/security_dashboard/graphql/queries/group_vulnerabilities.query.graphql
'
;
import
vulnerabilitiesQuery
from
'
ee/security_dashboard/graphql/queries/group_vulnerabilities.query.graphql
'
;
...
@@ -84,12 +85,11 @@ describe('Group Security Dashboard Vulnerabilities Component', () => {
...
@@ -84,12 +85,11 @@ describe('Group Security Dashboard Vulnerabilities Component', () => {
);
);
});
});
it
(
'
should have an alert that is dismissable
'
,
()
=>
{
it
(
'
should have an alert that is dismissable
'
,
async
()
=>
{
const
alert
=
findAlert
();
const
alert
=
findAlert
();
alert
.
vm
.
$emit
(
'
dismiss
'
);
alert
.
vm
.
$emit
(
'
dismiss
'
);
return
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
alert
.
exists
()).
toBe
(
false
);
expect
(
alert
.
exists
()).
toBe
(
false
);
});
});
});
it
(
'
does not display the vulnerabilities
'
,
()
=>
{
it
(
'
does not display the vulnerabilities
'
,
()
=>
{
...
...
ee/spec/frontend/security_dashboard/components/instance/instance_security_dashboard_spec.js
View file @
6979e878
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
InstanceSecurityDashboard
from
'
ee/security_dashboard/components/instance/instance_security_dashboard.vue
'
;
import
InstanceSecurityDashboard
from
'
ee/security_dashboard/components/instance/instance_security_dashboard.vue
'
;
import
ReportNotConfiguredInstance
from
'
ee/security_dashboard/components/shared/empty_states/report_not_configured_instance.vue
'
;
import
ReportNotConfiguredInstance
from
'
ee/security_dashboard/components/shared/empty_states/report_not_configured_instance.vue
'
;
import
VulnerabilitySeverities
from
'
ee/security_dashboard/components/shared/project_security_status_chart.vue
'
;
import
VulnerabilitySeverities
from
'
ee/security_dashboard/components/shared/project_security_status_chart.vue
'
;
...
@@ -96,7 +97,7 @@ describe('Instance Security Dashboard component', () => {
...
@@ -96,7 +97,7 @@ describe('Instance Security Dashboard component', () => {
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
projects
:
[{
name
:
'
project1
'
}]
});
wrapper
.
setData
({
projects
:
[{
name
:
'
project1
'
}]
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
securityChartsLayout
=
findSecurityChartsLayoutComponent
();
const
securityChartsLayout
=
findSecurityChartsLayoutComponent
();
const
reportNotConfigured
=
findReportNotConfigured
();
const
reportNotConfigured
=
findReportNotConfigured
();
...
...
ee/spec/frontend/security_dashboard/components/instance/instance_vulnerabilities_spec.js
View file @
6979e878
import
{
GlAlert
,
GlIntersectionObserver
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlAlert
,
GlIntersectionObserver
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
nextTick
}
from
'
vue
'
;
import
InstanceVulnerabilities
from
'
ee/security_dashboard/components/instance/instance_vulnerabilities.vue
'
;
import
InstanceVulnerabilities
from
'
ee/security_dashboard/components/instance/instance_vulnerabilities.vue
'
;
import
VulnerabilityList
from
'
ee/security_dashboard/components/shared/vulnerability_list.vue
'
;
import
VulnerabilityList
from
'
ee/security_dashboard/components/shared/vulnerability_list.vue
'
;
import
vulnerabilitiesQuery
from
'
ee/security_dashboard/graphql/queries/instance_vulnerabilities.query.graphql
'
;
import
vulnerabilitiesQuery
from
'
ee/security_dashboard/graphql/queries/instance_vulnerabilities.query.graphql
'
;
...
@@ -69,12 +70,11 @@ describe('Instance Security Dashboard Vulnerabilities Component', () => {
...
@@ -69,12 +70,11 @@ describe('Instance Security Dashboard Vulnerabilities Component', () => {
);
);
});
});
it
(
'
should have an alert that is dismissable
'
,
()
=>
{
it
(
'
should have an alert that is dismissable
'
,
async
()
=>
{
const
alert
=
findAlert
();
const
alert
=
findAlert
();
alert
.
vm
.
$emit
(
'
dismiss
'
);
alert
.
vm
.
$emit
(
'
dismiss
'
);
return
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
alert
.
exists
()).
toBe
(
false
);
expect
(
alert
.
exists
()).
toBe
(
false
);
});
});
});
it
(
'
does not display the vulnerabilities
'
,
()
=>
{
it
(
'
does not display the vulnerabilities
'
,
()
=>
{
...
...
ee/spec/frontend/security_dashboard/components/pipeline/filters_spec.js
View file @
6979e878
import
{
GlToggle
}
from
'
@gitlab/ui
'
;
import
{
GlToggle
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
,
mount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
,
mount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
Vuex
from
'
vuex
'
;
import
Vuex
from
'
vuex
'
;
import
Filters
from
'
ee/security_dashboard/components/pipeline/filters.vue
'
;
import
Filters
from
'
ee/security_dashboard/components/pipeline/filters.vue
'
;
import
{
simpleScannerFilter
}
from
'
ee/security_dashboard/helpers
'
;
import
{
simpleScannerFilter
}
from
'
ee/security_dashboard/helpers
'
;
...
@@ -69,7 +69,7 @@ describe('Filter component', () => {
...
@@ -69,7 +69,7 @@ describe('Filter component', () => {
});
});
createWrapper
({
mountFn
:
mount
});
createWrapper
({
mountFn
:
mount
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
// The other filters will trigger the mock as well, so we'll clear it before clicking on a
// The other filters will trigger the mock as well, so we'll clear it before clicking on a
// scanner filter item.
// scanner filter item.
mock
.
mockClear
();
mock
.
mockClear
();
...
@@ -78,7 +78,7 @@ describe('Filter component', () => {
...
@@ -78,7 +78,7 @@ describe('Filter component', () => {
const
optionId
=
simpleScannerFilter
.
options
[
2
].
id
;
const
optionId
=
simpleScannerFilter
.
options
[
2
].
id
;
const
option
=
wrapper
.
findByTestId
(
`
${
filterId
}
:
${
optionId
}
`
);
const
option
=
wrapper
.
findByTestId
(
`
${
filterId
}
:
${
optionId
}
`
);
option
.
vm
.
$emit
(
'
click
'
);
option
.
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
mock
).
toHaveBeenCalledTimes
(
1
);
expect
(
mock
).
toHaveBeenCalledTimes
(
1
);
expect
(
mock
).
toHaveBeenCalledWith
(
expect
.
any
(
Object
),
{
[
filterId
]:
[
optionId
]
});
expect
(
mock
).
toHaveBeenCalledWith
(
expect
.
any
(
Object
),
{
[
filterId
]:
[
optionId
]
});
...
...
ee/spec/frontend/security_dashboard/components/pipeline/security_reports_summary_spec.js
View file @
6979e878
import
{
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
SecurityReportsSummary
from
'
ee/security_dashboard/components/pipeline/security_reports_summary.vue
'
;
import
SecurityReportsSummary
from
'
ee/security_dashboard/components/pipeline/security_reports_summary.vue
'
;
import
Modal
from
'
ee/vue_shared/security_reports/components/dast_modal.vue
'
;
import
Modal
from
'
ee/vue_shared/security_reports/components/dast_modal.vue
'
;
import
{
mockPipelineJobs
}
from
'
ee_jest/security_dashboard/mock_data/jobs
'
;
import
{
mockPipelineJobs
}
from
'
ee_jest/security_dashboard/mock_data/jobs
'
;
...
@@ -148,7 +149,7 @@ describe('Security reports summary component', () => {
...
@@ -148,7 +149,7 @@ describe('Security reports summary component', () => {
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
isVisible
:
false
});
wrapper
.
setData
({
isVisible
:
false
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
localStorage
.
setItem
).
toHaveBeenCalledWith
(
LOCAL_STORAGE_KEY
,
'
1
'
);
expect
(
localStorage
.
setItem
).
toHaveBeenCalledWith
(
LOCAL_STORAGE_KEY
,
'
1
'
);
});
});
...
@@ -168,7 +169,7 @@ describe('Security reports summary component', () => {
...
@@ -168,7 +169,7 @@ describe('Security reports summary component', () => {
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
isVisible
:
true
});
wrapper
.
setData
({
isVisible
:
true
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
localStorage
.
removeItem
).
toHaveBeenCalledWith
(
LOCAL_STORAGE_KEY
);
expect
(
localStorage
.
removeItem
).
toHaveBeenCalledWith
(
LOCAL_STORAGE_KEY
);
});
});
...
...
ee/spec/frontend/security_dashboard/components/pipeline/selection_summary_vuex_spec.js
View file @
6979e878
import
{
GlButton
,
GlFormSelect
}
from
'
@gitlab/ui
'
;
import
{
GlButton
,
GlFormSelect
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
axios
from
'
axios
'
;
import
axios
from
'
axios
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
Vuex
from
'
vuex
'
;
import
Vuex
from
'
vuex
'
;
...
@@ -93,7 +93,7 @@ describe('Selection Summary', () => {
...
@@ -93,7 +93,7 @@ describe('Selection Summary', () => {
option
.
setSelected
();
option
.
setSelected
();
formSelect
().
trigger
(
'
change
'
);
formSelect
().
trigger
(
'
change
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
dismissalReason
).
toEqual
(
option
.
attributes
(
'
value
'
));
expect
(
wrapper
.
vm
.
dismissalReason
).
toEqual
(
option
.
attributes
(
'
value
'
));
expect
(
dismissButton
().
props
().
disabled
).
toBe
(
false
);
expect
(
dismissButton
().
props
().
disabled
).
toBe
(
false
);
...
...
ee/spec/frontend/security_dashboard/components/project/project_security_dashboard_spec.js
View file @
6979e878
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlLineChart
}
from
'
@gitlab/ui/dist/charts
'
;
import
{
GlLineChart
}
from
'
@gitlab/ui/dist/charts
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
ProjectSecurityDashboard
from
'
ee/security_dashboard/components/project/project_security_dashboard.vue
'
;
import
ProjectSecurityDashboard
from
'
ee/security_dashboard/components/project/project_security_dashboard.vue
'
;
import
ReportNotConfigured
from
'
ee/security_dashboard/components/shared/empty_states/report_not_configured_project.vue
'
;
import
ReportNotConfigured
from
'
ee/security_dashboard/components/shared/empty_states/report_not_configured_project.vue
'
;
...
@@ -78,13 +78,13 @@ describe('Project Security Dashboard component', () => {
...
@@ -78,13 +78,13 @@ describe('Project Security Dashboard component', () => {
});
});
describe
(
'
when chartWidth is 0
'
,
()
=>
{
describe
(
'
when chartWidth is 0
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
wrapper
=
createComponent
({
wrapper
=
createComponent
({
query
:
mockProjectSecurityChartsWithData
(),
query
:
mockProjectSecurityChartsWithData
(),
propsData
:
{
hasVulnerabilities
:
true
},
propsData
:
{
hasVulnerabilities
:
true
},
chartWidth
:
0
,
chartWidth
:
0
,
});
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
should not display the line chart
'
,
()
=>
{
it
(
'
should not display the line chart
'
,
()
=>
{
...
@@ -99,12 +99,12 @@ describe('Project Security Dashboard component', () => {
...
@@ -99,12 +99,12 @@ describe('Project Security Dashboard component', () => {
describe
(
'
when there is history data
'
,
()
=>
{
describe
(
'
when there is history data
'
,
()
=>
{
useFakeDate
(
2021
,
3
,
11
);
useFakeDate
(
2021
,
3
,
11
);
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
wrapper
=
createComponent
({
wrapper
=
createComponent
({
query
:
mockProjectSecurityChartsWithData
(),
query
:
mockProjectSecurityChartsWithData
(),
propsData
:
{
hasVulnerabilities
:
true
},
propsData
:
{
hasVulnerabilities
:
true
},
});
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
should display the chart with data
'
,
()
=>
{
it
(
'
should display the chart with data
'
,
()
=>
{
...
@@ -141,12 +141,12 @@ describe('Project Security Dashboard component', () => {
...
@@ -141,12 +141,12 @@ describe('Project Security Dashboard component', () => {
});
});
describe
(
'
when there is no history data
'
,
()
=>
{
describe
(
'
when there is no history data
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
wrapper
=
createComponent
({
wrapper
=
createComponent
({
query
:
mockProjectSecurityChartsWithoutData
(),
query
:
mockProjectSecurityChartsWithoutData
(),
propsData
:
{
hasVulnerabilities
:
false
},
propsData
:
{
hasVulnerabilities
:
false
},
});
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
should display the empty state
'
,
()
=>
{
it
(
'
should display the empty state
'
,
()
=>
{
...
@@ -191,7 +191,7 @@ describe('Project Security Dashboard component', () => {
...
@@ -191,7 +191,7 @@ describe('Project Security Dashboard component', () => {
secureVulnerabilityTrainingEnabled
:
false
,
secureVulnerabilityTrainingEnabled
:
false
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSecurityTrainingPromo
().
exists
()).
toBe
(
false
);
expect
(
findSecurityTrainingPromo
().
exists
()).
toBe
(
false
);
});
});
...
...
ee/spec/frontend/security_dashboard/components/project/project_vulnerabilities_spec.js
View file @
6979e878
...
@@ -2,6 +2,7 @@ import { GlAlert, GlIntersectionObserver, GlLoadingIcon } from '@gitlab/ui';
...
@@ -2,6 +2,7 @@ import { GlAlert, GlIntersectionObserver, GlLoadingIcon } from '@gitlab/ui';
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
{
Portal
}
from
'
portal-vue
'
;
import
{
Portal
}
from
'
portal-vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
nextTick
}
from
'
vue
'
;
import
ProjectVulnerabilities
from
'
ee/security_dashboard/components/project/project_vulnerabilities.vue
'
;
import
ProjectVulnerabilities
from
'
ee/security_dashboard/components/project/project_vulnerabilities.vue
'
;
import
SecurityScannerAlert
from
'
ee/security_dashboard/components/project/security_scanner_alert.vue
'
;
import
SecurityScannerAlert
from
'
ee/security_dashboard/components/project/security_scanner_alert.vue
'
;
import
VulnerabilityList
from
'
ee/security_dashboard/components/shared/vulnerability_list.vue
'
;
import
VulnerabilityList
from
'
ee/security_dashboard/components/shared/vulnerability_list.vue
'
;
...
@@ -325,7 +326,7 @@ describe('Vulnerabilities app component', () => {
...
@@ -325,7 +326,7 @@ describe('Vulnerabilities app component', () => {
scannerAlert
.
vm
.
$emit
(
'
dismiss
'
);
scannerAlert
.
vm
.
$emit
(
'
dismiss
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
scannerAlert
.
exists
()).
toBe
(
false
);
expect
(
scannerAlert
.
exists
()).
toBe
(
false
);
});
});
...
@@ -333,7 +334,7 @@ describe('Vulnerabilities app component', () => {
...
@@ -333,7 +334,7 @@ describe('Vulnerabilities app component', () => {
it
(
'
should remember the dismissal state
'
,
async
()
=>
{
it
(
'
should remember the dismissal state
'
,
async
()
=>
{
findSecurityScannerAlert
().
vm
.
$emit
(
'
dismiss
'
);
findSecurityScannerAlert
().
vm
.
$emit
(
'
dismiss
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
window
.
localStorage
.
setItem
.
mock
.
calls
).
toContainEqual
([
expect
(
window
.
localStorage
.
setItem
.
mock
.
calls
).
toContainEqual
([
ProjectVulnerabilities
.
SCANNER_ALERT_DISMISSED_LOCAL_STORAGE_KEY
,
ProjectVulnerabilities
.
SCANNER_ALERT_DISMISSED_LOCAL_STORAGE_KEY
,
...
...
ee/spec/frontend/security_dashboard/components/shared/csv_export_button_spec.js
View file @
6979e878
import
{
GlLoadingIcon
,
GlIcon
}
from
'
@gitlab/ui
'
;
import
{
GlLoadingIcon
,
GlIcon
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
{
nextTick
}
from
'
vue
'
;
import
CsvExportButton
,
{
import
CsvExportButton
,
{
STORAGE_KEY
,
STORAGE_KEY
,
}
from
'
ee/security_dashboard/components/shared/csv_export_button.vue
'
;
}
from
'
ee/security_dashboard/components/shared/csv_export_button.vue
'
;
...
@@ -118,7 +119,7 @@ describe('Csv Button Export', () => {
...
@@ -118,7 +119,7 @@ describe('Csv Button Export', () => {
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
isPreparingCsvExport
:
true
});
wrapper
.
setData
({
isPreparingCsvExport
:
true
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findCsvExportButton
().
props
()).
toMatchObject
({
expect
(
findCsvExportButton
().
props
()).
toMatchObject
({
icon
:
''
,
icon
:
''
,
...
@@ -134,7 +135,7 @@ describe('Csv Button Export', () => {
...
@@ -134,7 +135,7 @@ describe('Csv Button Export', () => {
it
(
'
closes the popover when the button is clicked
'
,
async
()
=>
{
it
(
'
closes the popover when the button is clicked
'
,
async
()
=>
{
expect
(
findPopoverButton
().
text
()).
toBe
(
'
Got it!
'
);
expect
(
findPopoverButton
().
text
()).
toBe
(
'
Got it!
'
);
findPopoverButton
().
vm
.
$emit
(
'
click
'
);
findPopoverButton
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findPopover
().
exists
()).
toBe
(
false
);
expect
(
findPopover
().
exists
()).
toBe
(
false
);
});
});
...
@@ -142,7 +143,7 @@ describe('Csv Button Export', () => {
...
@@ -142,7 +143,7 @@ describe('Csv Button Export', () => {
it
(
'
sets localStorage
'
,
async
()
=>
{
it
(
'
sets localStorage
'
,
async
()
=>
{
jest
.
spyOn
(
AccessorUtils
,
'
canUseLocalStorage
'
).
mockImplementation
(()
=>
true
);
jest
.
spyOn
(
AccessorUtils
,
'
canUseLocalStorage
'
).
mockImplementation
(()
=>
true
);
findPopoverButton
().
vm
.
$emit
(
'
click
'
);
findPopoverButton
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
localStorage
.
setItem
).
toHaveBeenCalledTimes
(
1
);
expect
(
localStorage
.
setItem
).
toHaveBeenCalledTimes
(
1
);
});
});
...
@@ -150,7 +151,7 @@ describe('Csv Button Export', () => {
...
@@ -150,7 +151,7 @@ describe('Csv Button Export', () => {
it
(
`does not set localStorage if it's not available`
,
async
()
=>
{
it
(
`does not set localStorage if it's not available`
,
async
()
=>
{
jest
.
spyOn
(
AccessorUtils
,
'
canUseLocalStorage
'
).
mockImplementation
(()
=>
false
);
jest
.
spyOn
(
AccessorUtils
,
'
canUseLocalStorage
'
).
mockImplementation
(()
=>
false
);
findPopoverButton
().
vm
.
$emit
(
'
click
'
);
findPopoverButton
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
localStorage
.
setItem
).
toHaveBeenCalledTimes
(
0
);
expect
(
localStorage
.
setItem
).
toHaveBeenCalledTimes
(
0
);
});
});
...
...
ee/spec/frontend/security_dashboard/components/shared/filters/filter_body_spec.js
View file @
6979e878
import
{
GlDropdown
,
GlSearchBoxByType
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlDropdown
,
GlSearchBoxByType
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
FilterBody
from
'
ee/security_dashboard/components/shared/filters/filter_body.vue
'
;
import
FilterBody
from
'
ee/security_dashboard/components/shared/filters/filter_body.vue
'
;
describe
(
'
Filter Body component
'
,
()
=>
{
describe
(
'
Filter Body component
'
,
()
=>
{
...
@@ -75,7 +76,7 @@ describe('Filter Body component', () => {
...
@@ -75,7 +76,7 @@ describe('Filter Body component', () => {
createComponent
({
showSearchBox
:
true
},
{
attachTo
:
document
.
body
});
createComponent
({
showSearchBox
:
true
},
{
attachTo
:
document
.
body
});
const
spy
=
jest
.
spyOn
(
searchBox
().
vm
,
'
focusInput
'
);
const
spy
=
jest
.
spyOn
(
searchBox
().
vm
,
'
focusInput
'
);
dropdown
().
vm
.
$emit
(
'
show
'
);
dropdown
().
vm
.
$emit
(
'
show
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
spy
).
toHaveBeenCalledTimes
(
1
);
expect
(
spy
).
toHaveBeenCalledTimes
(
1
);
});
});
...
@@ -84,7 +85,7 @@ describe('Filter Body component', () => {
...
@@ -84,7 +85,7 @@ describe('Filter Body component', () => {
const
text
=
'
abc
'
;
const
text
=
'
abc
'
;
createComponent
({
showSearchBox
:
true
});
createComponent
({
showSearchBox
:
true
});
searchBox
().
vm
.
$emit
(
'
input
'
,
text
);
searchBox
().
vm
.
$emit
(
'
input
'
,
text
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
(
'
input
'
)[
0
][
0
]).
toBe
(
text
);
expect
(
wrapper
.
emitted
(
'
input
'
)[
0
][
0
]).
toBe
(
text
);
});
});
...
...
ee/spec/frontend/security_dashboard/components/shared/filters/scanner_filter_spec.js
View file @
6979e878
import
{
GlDropdownItem
,
GlDropdownDivider
}
from
'
@gitlab/ui
'
;
import
{
GlDropdownItem
,
GlDropdownDivider
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
{
sampleSize
,
cloneDeep
}
from
'
lodash
'
;
import
{
sampleSize
,
cloneDeep
}
from
'
lodash
'
;
import
VueRouter
from
'
vue-router
'
;
import
VueRouter
from
'
vue-router
'
;
import
FilterItem
from
'
ee/security_dashboard/components/shared/filters/filter_item.vue
'
;
import
FilterItem
from
'
ee/security_dashboard/components/shared/filters/filter_item.vue
'
;
...
@@ -129,7 +129,7 @@ describe('Scanner Filter component', () => {
...
@@ -129,7 +129,7 @@ describe('Scanner Filter component', () => {
ids
.
includes
(
`
${
x
.
vendor
}
.
${
x
.
report_type
}
`
),
ids
.
includes
(
`
${
x
.
vendor
}
.
${
x
.
report_type
}
`
),
);
);
createWrapper
();
createWrapper
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
(
'
filter-changed
'
)[
0
][
0
]).
toEqual
({
expect
(
wrapper
.
emitted
(
'
filter-changed
'
)[
0
][
0
]).
toEqual
({
scannerId
:
expect
.
arrayContaining
([
scannerId
:
expect
.
arrayContaining
([
...
...
ee/spec/frontend/security_dashboard/components/shared/filters/simple_filter_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueRouter
from
'
vue-router
'
;
import
VueRouter
from
'
vue-router
'
;
import
SimpleFilter
from
'
ee/security_dashboard/components/shared/filters/simple_filter.vue
'
;
import
SimpleFilter
from
'
ee/security_dashboard/components/shared/filters/simple_filter.vue
'
;
...
@@ -37,12 +37,12 @@ describe('Simple Filter component', () => {
...
@@ -37,12 +37,12 @@ describe('Simple Filter component', () => {
const
clickAllOptionItem
=
async
()
=>
{
const
clickAllOptionItem
=
async
()
=>
{
allOptionItem
().
vm
.
$emit
(
'
click
'
);
allOptionItem
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
const
clickItemAt
=
async
(
index
)
=>
{
const
clickItemAt
=
async
(
index
)
=>
{
dropdownItemAt
(
index
).
vm
.
$emit
(
'
click
'
);
dropdownItemAt
(
index
).
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
const
expectSelectedItems
=
(
indexes
)
=>
{
const
expectSelectedItems
=
(
indexes
)
=>
{
...
@@ -157,7 +157,7 @@ describe('Simple Filter component', () => {
...
@@ -157,7 +157,7 @@ describe('Simple Filter component', () => {
// to fake it by doing it manually.
// to fake it by doing it manually.
router
.
replace
({
query
:
{
[
filter
.
id
]:
ids
}
});
router
.
replace
({
query
:
{
[
filter
.
id
]:
ids
}
});
window
.
dispatchEvent
(
new
Event
(
'
popstate
'
));
window
.
dispatchEvent
(
new
Event
(
'
popstate
'
));
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
describe
(
'
clicking on items
'
,
()
=>
{
describe
(
'
clicking on items
'
,
()
=>
{
...
@@ -295,7 +295,7 @@ describe('Simple Filter component', () => {
...
@@ -295,7 +295,7 @@ describe('Simple Filter component', () => {
const
query
=
{
[
filter
.
id
]:
ids
,
other
};
const
query
=
{
[
filter
.
id
]:
ids
,
other
};
router
.
push
({
query
});
router
.
push
({
query
});
window
.
dispatchEvent
(
new
Event
(
'
popstate
'
));
window
.
dispatchEvent
(
new
Event
(
'
popstate
'
));
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expectSelectedItems
([
1
,
2
,
3
]);
expectSelectedItems
([
1
,
2
,
3
]);
expect
(
wrapper
.
vm
.
$route
.
query
.
other
).
toEqual
(
other
);
expect
(
wrapper
.
vm
.
$route
.
query
.
other
).
toEqual
(
other
);
...
...
ee/spec/frontend/security_dashboard/components/shared/selection_summary_spec.js
View file @
6979e878
import
{
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
SelectionSummary
from
'
ee/security_dashboard/components/shared/selection_summary.vue
'
;
import
SelectionSummary
from
'
ee/security_dashboard/components/shared/selection_summary.vue
'
;
import
StatusDropdown
from
'
ee/security_dashboard/components/shared/status_dropdown.vue
'
;
import
StatusDropdown
from
'
ee/security_dashboard/components/shared/status_dropdown.vue
'
;
...
@@ -56,7 +56,7 @@ describe('Selection Summary component', () => {
...
@@ -56,7 +56,7 @@ describe('Selection Summary component', () => {
describe
(
'
with selected state
'
,
()
=>
{
describe
(
'
with selected state
'
,
()
=>
{
beforeEach
(
async
()
=>
{
beforeEach
(
async
()
=>
{
wrapper
.
findComponent
(
StatusDropdown
).
vm
.
$emit
(
'
change
'
,
{
action
:
'
confirm
'
});
wrapper
.
findComponent
(
StatusDropdown
).
vm
.
$emit
(
'
change
'
,
{
action
:
'
confirm
'
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
displays the submit button when there is s state selected
'
,
()
=>
{
it
(
'
displays the submit button when there is s state selected
'
,
()
=>
{
...
@@ -71,7 +71,7 @@ describe('Selection Summary component', () => {
...
@@ -71,7 +71,7 @@ describe('Selection Summary component', () => {
describe
(
'
with no selected state
'
,
()
=>
{
describe
(
'
with no selected state
'
,
()
=>
{
beforeEach
(
async
()
=>
{
beforeEach
(
async
()
=>
{
wrapper
.
findComponent
(
StatusDropdown
).
vm
.
$emit
(
'
change
'
,
{
action
:
null
});
wrapper
.
findComponent
(
StatusDropdown
).
vm
.
$emit
(
'
change
'
,
{
action
:
null
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
does not display the submit button when there is s state selected
'
,
()
=>
{
it
(
'
does not display the submit button when there is s state selected
'
,
()
=>
{
...
@@ -185,7 +185,7 @@ describe('Selection Summary component', () => {
...
@@ -185,7 +185,7 @@ describe('Selection Summary component', () => {
it
(
`the submit button is unclickable during form submission -
${
action
}
`
,
async
()
=>
{
it
(
`the submit button is unclickable during form submission -
${
action
}
`
,
async
()
=>
{
expect
(
findSubmitButton
().
exists
()).
toBe
(
false
);
expect
(
findSubmitButton
().
exists
()).
toBe
(
false
);
submitForm
();
submitForm
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
isSubmitButtonDisabled
()).
toBe
(
true
);
expect
(
isSubmitButtonDisabled
()).
toBe
(
true
);
await
waitForPromises
();
await
waitForPromises
();
expect
(
isSubmitButtonDisabled
()).
toBe
(
false
);
expect
(
isSubmitButtonDisabled
()).
toBe
(
false
);
...
...
ee/spec/frontend/security_dashboard/components/shared/vulnerabilities_over_time_chart_spec.js
View file @
6979e878
...
@@ -53,14 +53,13 @@ describe('Vulnerabilities Over Time Chart Component', () => {
...
@@ -53,14 +53,13 @@ describe('Vulnerabilities Over Time Chart Component', () => {
${
'
2000-01-01T00:00:00Z
'
}
|
${
30
}
|
${
'
December 2nd
'
}
${
'
2000-01-01T00:00:00Z
'
}
|
${
30
}
|
${
'
December 2nd
'
}
`
(
`
(
'
shows "$expectedStartDate" when the date range is set to "$dayRange" days
'
,
'
shows "$expectedStartDate" when the date range is set to "$dayRange" days
'
,
({
mockDate
,
dayRange
,
expectedStartDate
})
=>
{
async
({
mockDate
,
dayRange
,
expectedStartDate
})
=>
{
jest
.
spyOn
(
global
.
Date
,
'
now
'
).
mockImplementation
(()
=>
new
Date
(
mockDate
));
jest
.
spyOn
(
global
.
Date
,
'
now
'
).
mockImplementation
(()
=>
new
Date
(
mockDate
));
wrapper
=
createComponent
({
data
:
()
=>
({
vulnerabilitiesHistoryDayRange
:
dayRange
})
});
wrapper
=
createComponent
({
data
:
()
=>
({
vulnerabilitiesHistoryDayRange
:
dayRange
})
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
findTimeInfo
().
text
()).
toContain
(
expectedStartDate
);
expect
(
findTimeInfo
().
text
()).
toContain
(
expectedStartDate
);
});
},
},
);
);
});
});
...
...
ee/spec/frontend/security_dashboard/components/shared/vulnerability_count_list_spec.js
View file @
6979e878
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
nextTick
}
from
'
vue
'
;
import
VulnerabilityCountList
from
'
ee/security_dashboard/components/shared/vulnerability_count_list.vue
'
;
import
VulnerabilityCountList
from
'
ee/security_dashboard/components/shared/vulnerability_count_list.vue
'
;
import
VulnerabilityCountListLayout
from
'
ee/security_dashboard/components/shared/vulnerability_count_list_layout.vue
'
;
import
VulnerabilityCountListLayout
from
'
ee/security_dashboard/components/shared/vulnerability_count_list_layout.vue
'
;
import
countQuery
from
'
ee/security_dashboard/graphql/queries/vulnerability_severities_count.query.graphql
'
;
import
countQuery
from
'
ee/security_dashboard/graphql/queries/vulnerability_severities_count.query.graphql
'
;
...
@@ -101,7 +102,7 @@ describe('Vulnerabilities count list component', () => {
...
@@ -101,7 +102,7 @@ describe('Vulnerabilities count list component', () => {
`
(
`
(
'
when the dashboard type is $dashboardType
'
,
'
when the dashboard type is $dashboardType
'
,
({
dashboardType
,
provide
,
expectedContainedQueryVariables
})
=>
{
({
dashboardType
,
provide
,
expectedContainedQueryVariables
})
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
const
mockResponse
=
jest
const
mockResponse
=
jest
.
fn
()
.
fn
()
.
mockResolvedValue
(
mockVulnerabilitySeveritiesGraphQLResponse
({
dashboardType
}));
.
mockResolvedValue
(
mockVulnerabilitySeveritiesGraphQLResponse
({
dashboardType
}));
...
@@ -113,7 +114,7 @@ describe('Vulnerabilities count list component', () => {
...
@@ -113,7 +114,7 @@ describe('Vulnerabilities count list component', () => {
stubs
:
{
VulnerabilityCountListLayout
},
stubs
:
{
VulnerabilityCountListLayout
},
});
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
should pass the correct variables to the GraphQL query
'
,
()
=>
{
it
(
'
should pass the correct variables to the GraphQL query
'
,
()
=>
{
...
...
ee/spec/frontend/security_dashboard/components/shared/vulnerability_list_spec.js
View file @
6979e878
import
{
GlDeprecatedSkeletonLoading
as
GlSkeletonLoading
,
GlTable
,
GlTruncate
}
from
'
@gitlab/ui
'
;
import
{
GlDeprecatedSkeletonLoading
as
GlSkeletonLoading
,
GlTable
,
GlTruncate
}
from
'
@gitlab/ui
'
;
import
{
capitalize
}
from
'
lodash
'
;
import
{
capitalize
}
from
'
lodash
'
;
import
{
nextTick
}
from
'
vue
'
;
import
DashboardHasNoVulnerabilities
from
'
ee/security_dashboard/components/shared/empty_states/dashboard_has_no_vulnerabilities.vue
'
;
import
DashboardHasNoVulnerabilities
from
'
ee/security_dashboard/components/shared/empty_states/dashboard_has_no_vulnerabilities.vue
'
;
import
FiltersProducedNoResults
from
'
ee/security_dashboard/components/shared/empty_states/filters_produced_no_results.vue
'
;
import
FiltersProducedNoResults
from
'
ee/security_dashboard/components/shared/empty_states/filters_produced_no_results.vue
'
;
import
IssuesBadge
from
'
ee/security_dashboard/components/shared/issues_badge.vue
'
;
import
IssuesBadge
from
'
ee/security_dashboard/components/shared/issues_badge.vue
'
;
...
@@ -148,7 +149,7 @@ describe('Vulnerability list component', () => {
...
@@ -148,7 +149,7 @@ describe('Vulnerability list component', () => {
it
(
'
should show the selection summary when a checkbox is selected
'
,
async
()
=>
{
it
(
'
should show the selection summary when a checkbox is selected
'
,
async
()
=>
{
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
true
);
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
true
);
});
});
...
@@ -156,13 +157,13 @@ describe('Vulnerability list component', () => {
...
@@ -156,13 +157,13 @@ describe('Vulnerability list component', () => {
it
(
'
should sync selected vulnerabilities when the vulnerability list is updated
'
,
async
()
=>
{
it
(
'
should sync selected vulnerabilities when the vulnerability list is updated
'
,
async
()
=>
{
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
(
'
selectedVulnerabilities
'
)).
toHaveLength
(
1
);
expect
(
findSelectionSummary
().
props
(
'
selectedVulnerabilities
'
)).
toHaveLength
(
1
);
wrapper
.
setProps
({
vulnerabilities
:
[]
});
wrapper
.
setProps
({
vulnerabilities
:
[]
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
false
);
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
false
);
});
});
...
@@ -172,9 +173,9 @@ describe('Vulnerability list component', () => {
...
@@ -172,9 +173,9 @@ describe('Vulnerability list component', () => {
checkbox
().
setChecked
(
true
);
checkbox
().
setChecked
(
true
);
expect
(
checkbox
().
element
.
checked
).
toBe
(
true
);
expect
(
checkbox
().
element
.
checked
).
toBe
(
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
findSelectionSummary
().
vm
.
$emit
(
'
vulnerability-updated
'
,
newVulnerabilities
[
0
].
id
);
findSelectionSummary
().
vm
.
$emit
(
'
vulnerability-updated
'
,
newVulnerabilities
[
0
].
id
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
checkbox
().
element
.
checked
).
toBe
(
false
);
expect
(
checkbox
().
element
.
checked
).
toBe
(
false
);
});
});
...
@@ -626,11 +627,11 @@ describe('Vulnerability list component', () => {
...
@@ -626,11 +627,11 @@ describe('Vulnerability list component', () => {
};
};
clickRows
();
clickRows
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expectRowCheckboxesToBe
((
i
)
=>
rowsToClick
.
includes
(
i
));
expectRowCheckboxesToBe
((
i
)
=>
rowsToClick
.
includes
(
i
));
clickRows
();
clickRows
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expectRowCheckboxesToBe
(()
=>
false
);
expectRowCheckboxesToBe
(()
=>
false
);
});
});
});
});
...
...
ee/spec/frontend/security_dashboard/components/shared/vulnerability_report/vulnerability_list_spec.js
View file @
6979e878
import
{
GlSkeletonLoading
,
GlTable
,
GlTruncate
}
from
'
@gitlab/ui
'
;
import
{
GlSkeletonLoading
,
GlTable
,
GlTruncate
}
from
'
@gitlab/ui
'
;
import
{
capitalize
}
from
'
lodash
'
;
import
{
capitalize
}
from
'
lodash
'
;
import
{
Portal
}
from
'
portal-vue
'
;
import
{
Portal
}
from
'
portal-vue
'
;
import
{
nextTick
}
from
'
vue
'
;
import
DashboardHasNoVulnerabilities
from
'
ee/security_dashboard/components/shared/empty_states/dashboard_has_no_vulnerabilities.vue
'
;
import
DashboardHasNoVulnerabilities
from
'
ee/security_dashboard/components/shared/empty_states/dashboard_has_no_vulnerabilities.vue
'
;
import
FiltersProducedNoResults
from
'
ee/security_dashboard/components/shared/empty_states/filters_produced_no_results.vue
'
;
import
FiltersProducedNoResults
from
'
ee/security_dashboard/components/shared/empty_states/filters_produced_no_results.vue
'
;
import
IssuesBadge
from
'
ee/security_dashboard/components/shared/issues_badge.vue
'
;
import
IssuesBadge
from
'
ee/security_dashboard/components/shared/issues_badge.vue
'
;
...
@@ -159,7 +160,7 @@ describe('Vulnerability list component', () => {
...
@@ -159,7 +160,7 @@ describe('Vulnerability list component', () => {
it
(
'
should show the selection summary when a checkbox is selected
'
,
async
()
=>
{
it
(
'
should show the selection summary when a checkbox is selected
'
,
async
()
=>
{
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
true
);
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
true
);
});
});
...
@@ -167,13 +168,13 @@ describe('Vulnerability list component', () => {
...
@@ -167,13 +168,13 @@ describe('Vulnerability list component', () => {
it
(
'
should sync selected vulnerabilities when the vulnerability list is updated
'
,
async
()
=>
{
it
(
'
should sync selected vulnerabilities when the vulnerability list is updated
'
,
async
()
=>
{
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
findDataCell
(
'
vulnerability-checkbox
'
).
setChecked
(
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
(
'
selectedVulnerabilities
'
)).
toHaveLength
(
1
);
expect
(
findSelectionSummary
().
props
(
'
selectedVulnerabilities
'
)).
toHaveLength
(
1
);
wrapper
.
setProps
({
vulnerabilities
:
[]
});
wrapper
.
setProps
({
vulnerabilities
:
[]
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
false
);
expect
(
findSelectionSummary
().
props
(
'
visible
'
)).
toBe
(
false
);
});
});
...
@@ -183,9 +184,9 @@ describe('Vulnerability list component', () => {
...
@@ -183,9 +184,9 @@ describe('Vulnerability list component', () => {
checkbox
().
setChecked
(
true
);
checkbox
().
setChecked
(
true
);
expect
(
checkbox
().
element
.
checked
).
toBe
(
true
);
expect
(
checkbox
().
element
.
checked
).
toBe
(
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
findSelectionSummary
().
vm
.
$emit
(
'
vulnerability-updated
'
,
newVulnerabilities
[
0
].
id
);
findSelectionSummary
().
vm
.
$emit
(
'
vulnerability-updated
'
,
newVulnerabilities
[
0
].
id
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
checkbox
().
element
.
checked
).
toBe
(
false
);
expect
(
checkbox
().
element
.
checked
).
toBe
(
false
);
});
});
...
@@ -230,7 +231,7 @@ describe('Vulnerability list component', () => {
...
@@ -230,7 +231,7 @@ describe('Vulnerability list component', () => {
it
(
'
should not select a clicked vulnerability
'
,
async
()
=>
{
it
(
'
should not select a clicked vulnerability
'
,
async
()
=>
{
findRow
(
1
).
trigger
(
'
click
'
);
findRow
(
1
).
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findSelectionSummary
().
props
()).
toMatchObject
({
expect
(
findSelectionSummary
().
props
()).
toMatchObject
({
visible
:
false
,
visible
:
false
,
...
@@ -602,11 +603,11 @@ describe('Vulnerability list component', () => {
...
@@ -602,11 +603,11 @@ describe('Vulnerability list component', () => {
};
};
clickRows
();
clickRows
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expectRowCheckboxesToBe
((
i
)
=>
rowsToClick
.
includes
(
i
));
expectRowCheckboxesToBe
((
i
)
=>
rowsToClick
.
includes
(
i
));
clickRows
();
clickRows
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expectRowCheckboxesToBe
(()
=>
false
);
expectRowCheckboxesToBe
(()
=>
false
);
});
});
});
});
...
...
ee/spec/frontend/sidebar/components/cve_id_request_spec.js
View file @
6979e878
import
{
getByTestId
as
getByTestIdHelper
,
within
}
from
'
@testing-library/dom
'
;
import
{
getByTestId
as
getByTestIdHelper
,
within
}
from
'
@testing-library/dom
'
;
import
{
createWrapper
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
createWrapper
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
CveIdRequest
from
'
ee/sidebar/components/cve_id_request/cve_id_request_sidebar.vue
'
;
import
CveIdRequest
from
'
ee/sidebar/components/cve_id_request/cve_id_request_sidebar.vue
'
;
import
{
store
}
from
'
~/notes/stores
'
;
import
{
store
}
from
'
~/notes/stores
'
;
...
@@ -59,7 +60,7 @@ describe('CveIdRequest', () => {
...
@@ -59,7 +60,7 @@ describe('CveIdRequest', () => {
it
(
'
should show the "Help" pane when help button is clicked
'
,
async
()
=>
{
it
(
'
should show the "Help" pane when help button is clicked
'
,
async
()
=>
{
findHelpButton
().
trigger
(
'
click
'
);
findHelpButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
showHelpState
).
toBe
(
true
);
expect
(
wrapper
.
vm
.
showHelpState
).
toBe
(
true
);
// let animations run
// let animations run
...
@@ -71,10 +72,10 @@ describe('CveIdRequest', () => {
...
@@ -71,10 +72,10 @@ describe('CveIdRequest', () => {
it
(
'
should not show the "Help" pane when help button is clicked and then closed
'
,
async
()
=>
{
it
(
'
should not show the "Help" pane when help button is clicked and then closed
'
,
async
()
=>
{
findHelpButton
().
trigger
(
'
click
'
);
findHelpButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
findCloseHelpButton
().
trigger
(
'
click
'
);
findCloseHelpButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
showHelpState
).
toBe
(
false
);
expect
(
wrapper
.
vm
.
showHelpState
).
toBe
(
false
);
expect
(
queryHelpPane
()).
toBe
(
null
);
expect
(
queryHelpPane
()).
toBe
(
null
);
...
...
ee/spec/frontend/sidebar/components/iteration_dropdown_spec.js
View file @
6979e878
...
@@ -7,7 +7,7 @@ import {
...
@@ -7,7 +7,7 @@ import {
GlSearchBoxByType
,
GlSearchBoxByType
,
}
from
'
@gitlab/ui
'
;
}
from
'
@gitlab/ui
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
IterationDropdown
from
'
ee/sidebar/components/iteration_dropdown.vue
'
;
import
IterationDropdown
from
'
ee/sidebar/components/iteration_dropdown.vue
'
;
import
groupIterationsQuery
from
'
ee/sidebar/queries/iterations.query.graphql
'
;
import
groupIterationsQuery
from
'
ee/sidebar/queries/iterations.query.graphql
'
;
...
@@ -80,7 +80,7 @@ describe('IterationDropdown', () => {
...
@@ -80,7 +80,7 @@ describe('IterationDropdown', () => {
});
});
const
waitForDebounce
=
async
()
=>
{
const
waitForDebounce
=
async
()
=>
{
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
jest
.
runOnlyPendingTimers
();
jest
.
runOnlyPendingTimers
();
};
};
const
findDropdownItems
=
()
=>
wrapper
.
findAllComponents
(
GlDropdownItem
);
const
findDropdownItems
=
()
=>
wrapper
.
findAllComponents
(
GlDropdownItem
);
...
@@ -97,7 +97,7 @@ describe('IterationDropdown', () => {
...
@@ -97,7 +97,7 @@ describe('IterationDropdown', () => {
item
.
vm
.
$emit
(
'
click
'
);
item
.
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
const
findDropdown
=
()
=>
wrapper
.
findComponent
(
GlDropdown
);
const
findDropdown
=
()
=>
wrapper
.
findComponent
(
GlDropdown
);
const
showDropdownAndWait
=
async
()
=>
{
const
showDropdownAndWait
=
async
()
=>
{
...
...
ee/spec/frontend/sidebar/components/status/status_spec.js
View file @
6979e878
import
{
GlDropdown
,
GlDropdownItem
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
GlDropdown
,
GlDropdownItem
,
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
Status
from
'
ee/sidebar/components/status/status.vue
'
;
import
Status
from
'
ee/sidebar/components/status/status.vue
'
;
import
{
healthStatus
,
healthStatusTextMap
,
I18N_DROPDOWN
}
from
'
ee/sidebar/constants
'
;
import
{
healthStatus
,
healthStatusTextMap
,
I18N_DROPDOWN
}
from
'
ee/sidebar/constants
'
;
import
{
createMockDirective
,
getBinding
}
from
'
helpers/vue_mock_directive
'
;
import
{
createMockDirective
,
getBinding
}
from
'
helpers/vue_mock_directive
'
;
...
@@ -149,11 +150,11 @@ describe('Status', () => {
...
@@ -149,11 +150,11 @@ describe('Status', () => {
wrapper
.
vm
.
isDropdownShowing
=
true
;
wrapper
.
vm
.
isDropdownShowing
=
true
;
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
getRemoveStatusItem
(
wrapper
).
exists
()).
toBe
(
true
);
expect
(
getRemoveStatusItem
(
wrapper
).
exists
()).
toBe
(
true
);
});
});
it
(
'
emits an onDropdownClick event with argument null when clicked
'
,
()
=>
{
it
(
'
emits an onDropdownClick event with argument null when clicked
'
,
async
()
=>
{
const
props
=
{
const
props
=
{
isEditable
:
true
,
isEditable
:
true
,
status
:
healthStatus
.
AT_RISK
,
status
:
healthStatus
.
AT_RISK
,
...
@@ -163,11 +164,10 @@ describe('Status', () => {
...
@@ -163,11 +164,10 @@ describe('Status', () => {
wrapper
.
vm
.
isDropdownShowing
=
true
;
wrapper
.
vm
.
isDropdownShowing
=
true
;
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
getRemoveStatusItem
(
wrapper
).
vm
.
$emit
(
'
click
'
,
{
preventDefault
:
()
=>
null
});
getRemoveStatusItem
(
wrapper
).
vm
.
$emit
(
'
click
'
,
{
preventDefault
:
()
=>
null
});
expect
(
wrapper
.
emitted
().
onDropdownClick
[
0
]).
toEqual
([
null
]);
expect
(
wrapper
.
emitted
().
onDropdownClick
[
0
]).
toEqual
([
null
]);
});
});
});
});
});
...
@@ -240,7 +240,7 @@ describe('Status', () => {
...
@@ -240,7 +240,7 @@ describe('Status', () => {
it
(
'
shows the dropdown when the Edit button is clicked
'
,
async
()
=>
{
it
(
'
shows the dropdown when the Edit button is clicked
'
,
async
()
=>
{
getEditButton
(
wrapper
).
trigger
(
'
click
'
);
getEditButton
(
wrapper
).
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
getDropdownClasses
(
wrapper
)).
toContain
(
'
show
'
);
expect
(
getDropdownClasses
(
wrapper
)).
toContain
(
'
show
'
);
});
});
});
});
...
@@ -268,7 +268,7 @@ describe('Status', () => {
...
@@ -268,7 +268,7 @@ describe('Status', () => {
it
(
'
hides form when the `edit` button is clicked
'
,
async
()
=>
{
it
(
'
hides form when the `edit` button is clicked
'
,
async
()
=>
{
getEditButton
(
wrapper
).
trigger
(
'
click
'
);
getEditButton
(
wrapper
).
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
getDropdownClasses
(
wrapper
)).
toContain
(
'
gl-display-none
'
);
expect
(
getDropdownClasses
(
wrapper
)).
toContain
(
'
gl-display-none
'
);
});
});
...
@@ -277,7 +277,7 @@ describe('Status', () => {
...
@@ -277,7 +277,7 @@ describe('Status', () => {
dropdownItem
.
vm
.
$emit
(
'
click
'
);
dropdownItem
.
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
getDropdownClasses
(
wrapper
)).
toContain
(
'
gl-display-none
'
);
expect
(
getDropdownClasses
(
wrapper
)).
toContain
(
'
gl-display-none
'
);
});
});
});
});
...
@@ -325,7 +325,7 @@ describe('Status', () => {
...
@@ -325,7 +325,7 @@ describe('Status', () => {
.
at
(
index
+
1
)
.
at
(
index
+
1
)
.
vm
.
$emit
(
'
click
'
,
{
preventDefault
:
()
=>
null
});
.
vm
.
$emit
(
'
click
'
,
{
preventDefault
:
()
=>
null
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
().
onDropdownClick
[
0
]).
toEqual
([
status
]);
expect
(
wrapper
.
emitted
().
onDropdownClick
[
0
]).
toEqual
([
status
]);
},
},
);
);
...
...
ee/spec/frontend/sidebar/weight_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
Weight
from
'
ee/sidebar/components/weight/weight.vue
'
;
import
Weight
from
'
ee/sidebar/components/weight/weight.vue
'
;
import
{
mockTracking
,
unmockTracking
,
triggerEvent
}
from
'
helpers/tracking_helper
'
;
import
{
mockTracking
,
unmockTracking
,
triggerEvent
}
from
'
helpers/tracking_helper
'
;
import
{
ENTER_KEY_CODE
}
from
'
~/lib/utils/keycodes
'
;
import
{
ENTER_KEY_CODE
}
from
'
~/lib/utils/keycodes
'
;
...
@@ -85,7 +86,7 @@ describe('Weight', () => {
...
@@ -85,7 +86,7 @@ describe('Weight', () => {
findCollapsedBlock
().
trigger
(
'
click
'
);
findCollapsedBlock
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
expect
(
wrapper
.
classes
()).
toContain
(
'
collapse-after-update
'
);
expect
(
wrapper
.
classes
()).
toContain
(
'
collapse-after-update
'
);
});
});
...
@@ -99,7 +100,7 @@ describe('Weight', () => {
...
@@ -99,7 +100,7 @@ describe('Weight', () => {
findEditLink
().
trigger
(
'
click
'
);
findEditLink
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
expect
(
containsEditableField
()).
toBe
(
true
);
expect
(
containsEditableField
()).
toBe
(
true
);
});
});
...
@@ -117,7 +118,7 @@ describe('Weight', () => {
...
@@ -117,7 +118,7 @@ describe('Weight', () => {
findEditLink
().
trigger
(
'
click
'
);
findEditLink
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
const
event
=
new
CustomEvent
(
'
keydown
'
);
const
event
=
new
CustomEvent
(
'
keydown
'
);
event
.
keyCode
=
ENTER_KEY_CODE
;
event
.
keyCode
=
ENTER_KEY_CODE
;
...
@@ -127,7 +128,7 @@ describe('Weight', () => {
...
@@ -127,7 +128,7 @@ describe('Weight', () => {
editableField
.
value
=
expectedWeightValue
;
editableField
.
value
=
expectedWeightValue
;
editableField
.
dispatchEvent
(
event
);
editableField
.
dispatchEvent
(
event
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
expect
(
containsInputError
()).
toBe
(
false
);
expect
(
containsInputError
()).
toBe
(
false
);
expect
(
eventHub
.
$emit
).
toHaveBeenCalledWith
(
'
updateWeight
'
,
{
expect
(
eventHub
.
$emit
).
toHaveBeenCalledWith
(
'
updateWeight
'
,
{
...
@@ -149,7 +150,7 @@ describe('Weight', () => {
...
@@ -149,7 +150,7 @@ describe('Weight', () => {
findRemoveLink
().
trigger
(
'
click
'
);
findRemoveLink
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
expect
(
containsInputError
()).
toBe
(
false
);
expect
(
containsInputError
()).
toBe
(
false
);
expect
(
eventHub
.
$emit
).
toHaveBeenCalledWith
(
'
updateWeight
'
,
{
id
:
mockId
,
value
:
''
});
expect
(
eventHub
.
$emit
).
toHaveBeenCalledWith
(
'
updateWeight
'
,
{
id
:
mockId
,
value
:
''
});
...
@@ -162,7 +163,7 @@ describe('Weight', () => {
...
@@ -162,7 +163,7 @@ describe('Weight', () => {
findEditLink
().
trigger
(
'
click
'
);
findEditLink
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
const
event
=
new
CustomEvent
(
'
keydown
'
);
const
event
=
new
CustomEvent
(
'
keydown
'
);
event
.
keyCode
=
ENTER_KEY_CODE
;
event
.
keyCode
=
ENTER_KEY_CODE
;
...
@@ -172,7 +173,7 @@ describe('Weight', () => {
...
@@ -172,7 +173,7 @@ describe('Weight', () => {
editableField
.
value
=
-
9001
;
editableField
.
value
=
-
9001
;
editableField
.
dispatchEvent
(
event
);
editableField
.
dispatchEvent
(
event
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
expect
(
containsInputError
()).
toBe
(
true
);
expect
(
containsInputError
()).
toBe
(
true
);
});
});
...
@@ -197,7 +198,7 @@ describe('Weight', () => {
...
@@ -197,7 +198,7 @@ describe('Weight', () => {
it
(
'
calls trackEvent when "Edit" is clicked
'
,
async
()
=>
{
it
(
'
calls trackEvent when "Edit" is clicked
'
,
async
()
=>
{
triggerEvent
(
findEditLink
().
element
);
triggerEvent
(
findEditLink
().
element
);
await
wrapper
.
vm
.
$
nextTick
;
await
nextTick
;
expect
(
trackingSpy
).
toHaveBeenCalled
();
expect
(
trackingSpy
).
toHaveBeenCalled
();
});
});
...
...
ee/spec/frontend/subscriptions/buy_addons_shared/components/order_summary_spec.js
View file @
6979e878
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
{
merge
}
from
'
lodash
'
;
import
{
merge
}
from
'
lodash
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
...
@@ -162,7 +162,7 @@ describe('Order Summary', () => {
...
@@ -162,7 +162,7 @@ describe('Order Summary', () => {
it
(
'
should emit `alertError` event
'
,
async
()
=>
{
it
(
'
should emit `alertError` event
'
,
async
()
=>
{
jest
.
spyOn
(
wrapper
.
vm
,
'
$emit
'
);
jest
.
spyOn
(
wrapper
.
vm
,
'
$emit
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
$emit
).
toHaveBeenCalledWith
(
'
alertError
'
,
I18N_API_ERROR
);
expect
(
wrapper
.
vm
.
$emit
).
toHaveBeenCalledWith
(
'
alertError
'
,
I18N_API_ERROR
);
});
});
...
...
ee/spec/frontend/test_case_create/components/test_case_create_root_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
TestCaseCreateRoot
from
'
ee/test_case_create/components/test_case_create_root.vue
'
;
import
TestCaseCreateRoot
from
'
ee/test_case_create/components/test_case_create_root.vue
'
;
import
createTestCase
from
'
ee/test_case_create/queries/create_test_case.mutation.graphql
'
;
import
createTestCase
from
'
ee/test_case_create/queries/create_test_case.mutation.graphql
'
;
...
@@ -185,7 +186,7 @@ describe('TestCaseCreateRoot', () => {
...
@@ -185,7 +186,7 @@ describe('TestCaseCreateRoot', () => {
createTestCaseRequestActive
:
true
,
createTestCaseRequestActive
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
find
(
'
[data-testid="submit-test-case"]
'
).
props
(
'
loading
'
)).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
[data-testid="submit-test-case"]
'
).
props
(
'
loading
'
)).
toBe
(
true
);
});
});
...
@@ -197,7 +198,7 @@ describe('TestCaseCreateRoot', () => {
...
@@ -197,7 +198,7 @@ describe('TestCaseCreateRoot', () => {
createTestCaseRequestActive
:
true
,
createTestCaseRequestActive
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
find
(
'
[data-testid="cancel-test-case"]
'
).
props
(
'
disabled
'
)).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
[data-testid="cancel-test-case"]
'
).
props
(
'
disabled
'
)).
toBe
(
true
);
});
});
...
...
ee/spec/frontend/test_case_list/components/test_case_list_empty_spec.js
View file @
6979e878
import
{
GlEmptyState
,
GlSprintf
,
GlButton
}
from
'
@gitlab/ui
'
;
import
{
GlEmptyState
,
GlSprintf
,
GlButton
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
TestCaseListEmptyState
from
'
ee/test_case_list/components/test_case_list_empty_state.vue
'
;
import
TestCaseListEmptyState
from
'
ee/test_case_list/components/test_case_list_empty_state.vue
'
;
const
createComponent
=
(
props
=
{})
=>
const
createComponent
=
(
props
=
{})
=>
...
@@ -44,7 +45,7 @@ describe('TestCaseListEmptyState', () => {
...
@@ -44,7 +45,7 @@ describe('TestCaseListEmptyState', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
emptyStateTitle
).
toBe
(
'
There are no open test cases
'
);
expect
(
wrapper
.
vm
.
emptyStateTitle
).
toBe
(
'
There are no open test cases
'
);
});
});
...
@@ -59,7 +60,7 @@ describe('TestCaseListEmptyState', () => {
...
@@ -59,7 +60,7 @@ describe('TestCaseListEmptyState', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
emptyStateTitle
).
toBe
(
'
There are no archived test cases
'
);
expect
(
wrapper
.
vm
.
emptyStateTitle
).
toBe
(
'
There are no archived test cases
'
);
});
});
...
@@ -87,7 +88,7 @@ describe('TestCaseListEmptyState', () => {
...
@@ -87,7 +88,7 @@ describe('TestCaseListEmptyState', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
showDescription
).
toBe
(
returnValue
);
expect
(
wrapper
.
vm
.
showDescription
).
toBe
(
returnValue
);
},
},
...
...
ee/spec/frontend/test_case_show/components/test_case_show_root_spec.js
View file @
6979e878
import
{
GlLink
,
GlLoadingIcon
,
GlSprintf
,
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
GlLink
,
GlLoadingIcon
,
GlSprintf
,
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
TestCaseShowRoot
from
'
ee/test_case_show/components/test_case_show_root.vue
'
;
import
TestCaseShowRoot
from
'
ee/test_case_show/components/test_case_show_root.vue
'
;
import
TestCaseSidebar
from
'
ee/test_case_show/components/test_case_sidebar.vue
'
;
import
TestCaseSidebar
from
'
ee/test_case_show/components/test_case_sidebar.vue
'
;
import
{
mockCurrentUserTodo
}
from
'
jest/vue_shared/issuable/list/mock_data
'
;
import
{
mockCurrentUserTodo
}
from
'
jest/vue_shared/issuable/list/mock_data
'
;
...
@@ -94,7 +95,7 @@ describe('TestCaseShowRoot', () => {
...
@@ -94,7 +95,7 @@ describe('TestCaseShowRoot', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
.
each
`
it
.
each
`
...
@@ -243,7 +244,7 @@ describe('TestCaseShowRoot', () => {
...
@@ -243,7 +244,7 @@ describe('TestCaseShowRoot', () => {
editTestCaseFormVisible
:
true
,
editTestCaseFormVisible
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
vm
.
handleCancelClick
();
wrapper
.
vm
.
handleCancelClick
();
...
@@ -274,7 +275,7 @@ describe('TestCaseShowRoot', () => {
...
@@ -274,7 +275,7 @@ describe('TestCaseShowRoot', () => {
testCaseLoading
:
true
,
testCaseLoading
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findComponent
(
GlLoadingIcon
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
GlLoadingIcon
).
exists
()).
toBe
(
true
);
});
});
...
@@ -332,7 +333,7 @@ describe('TestCaseShowRoot', () => {
...
@@ -332,7 +333,7 @@ describe('TestCaseShowRoot', () => {
testCaseLoadFailed
:
true
,
testCaseLoadFailed
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findComponent
(
IssuableShow
).
exists
()).
toBe
(
false
);
expect
(
wrapper
.
findComponent
(
IssuableShow
).
exists
()).
toBe
(
false
);
});
});
...
@@ -375,7 +376,7 @@ describe('TestCaseShowRoot', () => {
...
@@ -375,7 +376,7 @@ describe('TestCaseShowRoot', () => {
editTestCaseFormVisible
:
true
,
editTestCaseFormVisible
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
find
(
'
[data-testid="save-test-case"]
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
[data-testid="save-test-case"]
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
[data-testid="cancel-test-case-edit"]
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
[data-testid="cancel-test-case-edit"]
'
).
exists
()).
toBe
(
true
);
...
@@ -390,7 +391,7 @@ describe('TestCaseShowRoot', () => {
...
@@ -390,7 +391,7 @@ describe('TestCaseShowRoot', () => {
expect
(
testCaseSidebar
.
props
(
'
sidebarExpanded
'
)).
toBe
(
true
);
expect
(
testCaseSidebar
.
props
(
'
sidebarExpanded
'
)).
toBe
(
true
);
testCaseSidebar
.
vm
.
$emit
(
'
sidebar-toggle
'
);
testCaseSidebar
.
vm
.
$emit
(
'
sidebar-toggle
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
testCaseSidebar
.
props
(
'
sidebarExpanded
'
)).
toBe
(
false
);
expect
(
testCaseSidebar
.
props
(
'
sidebarExpanded
'
)).
toBe
(
false
);
});
});
...
...
ee/spec/frontend/test_case_show/components/test_case_sidebar_spec.js
View file @
6979e878
...
@@ -2,6 +2,7 @@ import { GlButton, GlIcon } from '@gitlab/ui';
...
@@ -2,6 +2,7 @@ import { GlButton, GlIcon } from '@gitlab/ui';
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Mousetrap
from
'
mousetrap
'
;
import
Mousetrap
from
'
mousetrap
'
;
import
{
nextTick
}
from
'
vue
'
;
import
TestCaseSidebar
from
'
ee/test_case_show/components/test_case_sidebar.vue
'
;
import
TestCaseSidebar
from
'
ee/test_case_show/components/test_case_sidebar.vue
'
;
import
{
mockCurrentUserTodo
,
mockLabels
}
from
'
jest/vue_shared/issuable/list/mock_data
'
;
import
{
mockCurrentUserTodo
,
mockLabels
}
from
'
jest/vue_shared/issuable/list/mock_data
'
;
...
@@ -65,7 +66,7 @@ describe('TestCaseSidebar', () => {
...
@@ -65,7 +66,7 @@ describe('TestCaseSidebar', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
.
each
`
it
.
each
`
...
@@ -92,7 +93,7 @@ describe('TestCaseSidebar', () => {
...
@@ -92,7 +93,7 @@ describe('TestCaseSidebar', () => {
testCaseMoveInProgress
,
testCaseMoveInProgress
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
selectProjectDropdownButtonTitle
).
toBe
(
returnValue
);
expect
(
wrapper
.
vm
.
selectProjectDropdownButtonTitle
).
toBe
(
returnValue
);
},
},
...
@@ -126,7 +127,7 @@ describe('TestCaseSidebar', () => {
...
@@ -126,7 +127,7 @@ describe('TestCaseSidebar', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
vm
.
handleTodoButtonClick
();
wrapper
.
vm
.
handleTodoButtonClick
();
...
@@ -162,7 +163,7 @@ describe('TestCaseSidebar', () => {
...
@@ -162,7 +163,7 @@ describe('TestCaseSidebar', () => {
sidebarExpanded
:
false
,
sidebarExpanded
:
false
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
vm
.
expandSidebarAndOpenDropdown
(
'
.js-labels-block .js-sidebar-dropdown-toggle
'
);
wrapper
.
vm
.
expandSidebarAndOpenDropdown
(
'
.js-labels-block .js-sidebar-dropdown-toggle
'
);
...
@@ -178,11 +179,11 @@ describe('TestCaseSidebar', () => {
...
@@ -178,11 +179,11 @@ describe('TestCaseSidebar', () => {
sidebarExpanded
:
false
,
sidebarExpanded
:
false
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
vm
.
expandSidebarAndOpenDropdown
(
'
.js-labels-block .js-sidebar-dropdown-toggle
'
);
wrapper
.
vm
.
expandSidebarAndOpenDropdown
(
'
.js-labels-block .js-sidebar-dropdown-toggle
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
vm
.
sidebarEl
.
dispatchEvent
(
new
Event
(
'
transitionend
'
));
wrapper
.
vm
.
sidebarEl
.
dispatchEvent
(
new
Event
(
'
transitionend
'
));
...
@@ -205,7 +206,7 @@ describe('TestCaseSidebar', () => {
...
@@ -205,7 +206,7 @@ describe('TestCaseSidebar', () => {
sidebarExpandedOnClick
:
true
,
sidebarExpandedOnClick
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
vm
.
handleSidebarDropdownClose
();
wrapper
.
vm
.
handleSidebarDropdownClose
();
...
@@ -276,7 +277,7 @@ describe('TestCaseSidebar', () => {
...
@@ -276,7 +277,7 @@ describe('TestCaseSidebar', () => {
sidebarExpanded
:
false
,
sidebarExpanded
:
false
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
todoEl
=
wrapper
.
find
(
'
button
'
);
todoEl
=
wrapper
.
find
(
'
button
'
);
...
...
ee/spec/frontend/threat_monitoring/components/alerts/alert_drawer_spec.js
View file @
6979e878
...
@@ -2,6 +2,7 @@ import { GlAlert, GlDrawer, GlSkeletonLoader } from '@gitlab/ui';
...
@@ -2,6 +2,7 @@ import { GlAlert, GlDrawer, GlSkeletonLoader } from '@gitlab/ui';
import
*
as
Sentry
from
'
@sentry/browser
'
;
import
*
as
Sentry
from
'
@sentry/browser
'
;
import
{
createLocalVue
}
from
'
@vue/test-utils
'
;
import
{
createLocalVue
}
from
'
@vue/test-utils
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
nextTick
}
from
'
vue
'
;
import
AlertDrawer
from
'
ee/threat_monitoring/components/alerts/alert_drawer.vue
'
;
import
AlertDrawer
from
'
ee/threat_monitoring/components/alerts/alert_drawer.vue
'
;
import
{
DRAWER_ERRORS
}
from
'
ee/threat_monitoring/components/alerts/constants
'
;
import
{
DRAWER_ERRORS
}
from
'
ee/threat_monitoring/components/alerts/constants
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
...
@@ -104,7 +105,7 @@ describe('Alert Drawer', () => {
...
@@ -104,7 +105,7 @@ describe('Alert Drawer', () => {
${
'
skeleton loader
'
}
|
${
'
does not display
'
}
|
${
findSkeletonLoader
}
|
${
false
}
|
${
mountExtended
}
${
'
skeleton loader
'
}
|
${
'
does not display
'
}
|
${
findSkeletonLoader
}
|
${
false
}
|
${
mountExtended
}
`
(
'
$status the $component
'
,
async
({
findComponent
,
state
,
mount
})
=>
{
`
(
'
$status the $component
'
,
async
({
findComponent
,
state
,
mount
})
=>
{
createWrapper
({
$apollo
:
shallowApolloMock
({}),
mount
});
createWrapper
({
$apollo
:
shallowApolloMock
({}),
mount
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findComponent
().
exists
()).
toBe
(
state
);
expect
(
findComponent
().
exists
()).
toBe
(
state
);
});
});
});
});
...
...
ee/spec/frontend/threat_monitoring/components/alerts/alert_filters_spec.js
View file @
6979e878
import
{
GlDropdownItem
,
GlSearchBoxByType
}
from
'
@gitlab/ui
'
;
import
{
GlDropdownItem
,
GlSearchBoxByType
}
from
'
@gitlab/ui
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
AlertFilters
from
'
ee/threat_monitoring/components/alerts/alert_filters.vue
'
;
import
AlertFilters
from
'
ee/threat_monitoring/components/alerts/alert_filters.vue
'
;
import
{
ALL
,
DEFAULT_FILTERS
,
STATUSES
}
from
'
ee/threat_monitoring/components/alerts/constants
'
;
import
{
ALL
,
DEFAULT_FILTERS
,
STATUSES
}
from
'
ee/threat_monitoring/components/alerts/constants
'
;
import
{
trimText
}
from
'
helpers/text_helper
'
;
import
{
trimText
}
from
'
helpers/text_helper
'
;
...
@@ -38,7 +39,7 @@ describe('AlertFilters component', () => {
...
@@ -38,7 +39,7 @@ describe('AlertFilters component', () => {
const
searchTerm
=
'
abc
'
;
const
searchTerm
=
'
abc
'
;
const
search
=
findSearch
();
const
search
=
findSearch
();
search
.
vm
.
$emit
(
'
input
'
,
searchTerm
);
search
.
vm
.
$emit
(
'
input
'
,
searchTerm
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
(
'
filter-change
'
)).
toStrictEqual
([
expect
(
wrapper
.
emitted
(
'
filter-change
'
)).
toStrictEqual
([
[{
...
DEFAULT_FILTERS
,
searchTerm
}],
[{
...
DEFAULT_FILTERS
,
searchTerm
}],
]);
]);
...
...
ee/spec/frontend/threat_monitoring/components/alerts/alert_status_spec.js
View file @
6979e878
import
{
GlDropdown
,
GlDropdownItem
}
from
'
@gitlab/ui
'
;
import
{
GlDropdown
,
GlDropdownItem
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
AlertStatus
from
'
ee/threat_monitoring/components/alerts/alert_status.vue
'
;
import
AlertStatus
from
'
ee/threat_monitoring/components/alerts/alert_status.vue
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
updateAlertStatusMutation
from
'
~/graphql_shared/mutations/alert_status_update.mutation.graphql
'
;
import
updateAlertStatusMutation
from
'
~/graphql_shared/mutations/alert_status_update.mutation.graphql
'
;
...
@@ -96,7 +97,7 @@ describe('AlertStatus', () => {
...
@@ -96,7 +97,7 @@ describe('AlertStatus', () => {
it
(
'
emits an error when triggered a second time
'
,
async
()
=>
{
it
(
'
emits an error when triggered a second time
'
,
async
()
=>
{
await
selectFirstStatusOption
();
await
selectFirstStatusOption
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
await
selectFirstStatusOption
();
await
selectFirstStatusOption
();
expect
(
wrapper
.
emitted
(
'
alert-error
'
).
length
).
toBeGreaterThan
(
1
);
expect
(
wrapper
.
emitted
(
'
alert-error
'
).
length
).
toBeGreaterThan
(
1
);
});
});
...
@@ -105,7 +106,7 @@ describe('AlertStatus', () => {
...
@@ -105,7 +106,7 @@ describe('AlertStatus', () => {
const
status
=
'
Unreviewed
'
;
const
status
=
'
Unreviewed
'
;
expect
(
findStatusDropdown
().
props
(
'
text
'
)).
toBe
(
status
);
expect
(
findStatusDropdown
().
props
(
'
text
'
)).
toBe
(
status
);
await
selectFirstStatusOption
();
await
selectFirstStatusOption
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findStatusDropdown
().
props
(
'
text
'
)).
toBe
(
status
);
expect
(
findStatusDropdown
().
props
(
'
text
'
)).
toBe
(
status
);
});
});
});
});
...
...
ee/spec/frontend/threat_monitoring/components/alerts/alerts_list_spec.js
View file @
6979e878
import
{
GlIntersectionObserver
,
GlSkeletonLoading
}
from
'
@gitlab/ui
'
;
import
{
GlIntersectionObserver
,
GlSkeletonLoading
}
from
'
@gitlab/ui
'
;
import
{
createLocalVue
}
from
'
@vue/test-utils
'
;
import
{
createLocalVue
}
from
'
@vue/test-utils
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
nextTick
}
from
'
vue
'
;
import
AlertFilters
from
'
ee/threat_monitoring/components/alerts/alert_filters.vue
'
;
import
AlertFilters
from
'
ee/threat_monitoring/components/alerts/alert_filters.vue
'
;
import
AlertStatus
from
'
ee/threat_monitoring/components/alerts/alert_status.vue
'
;
import
AlertStatus
from
'
ee/threat_monitoring/components/alerts/alert_status.vue
'
;
import
AlertsList
from
'
ee/threat_monitoring/components/alerts/alerts_list.vue
'
;
import
AlertsList
from
'
ee/threat_monitoring/components/alerts/alerts_list.vue
'
;
...
@@ -129,7 +130,7 @@ describe('AlertsList component', () => {
...
@@ -129,7 +130,7 @@ describe('AlertsList component', () => {
const
newFilters
=
{
statuses
:
[]
};
const
newFilters
=
{
statuses
:
[]
};
expect
(
wrapper
.
vm
.
filters
).
toEqual
(
DEFAULT_FILTERS
);
expect
(
wrapper
.
vm
.
filters
).
toEqual
(
DEFAULT_FILTERS
);
findAlertFilters
().
vm
.
$emit
(
'
filter-change
'
,
newFilters
);
findAlertFilters
().
vm
.
$emit
(
'
filter-change
'
,
newFilters
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
filters
).
toEqual
(
newFilters
);
expect
(
wrapper
.
vm
.
filters
).
toEqual
(
newFilters
);
});
});
...
@@ -170,13 +171,13 @@ describe('AlertsList component', () => {
...
@@ -170,13 +171,13 @@ describe('AlertsList component', () => {
expect
(
findStatusColumnHeader
().
attributes
(
'
aria-sort
'
)).
toBe
(
'
none
'
);
expect
(
findStatusColumnHeader
().
attributes
(
'
aria-sort
'
)).
toBe
(
'
none
'
);
findStatusColumnHeader
().
trigger
(
'
click
'
);
findStatusColumnHeader
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
sort
).
toBe
(
'
STATUS_DESC
'
);
expect
(
wrapper
.
vm
.
sort
).
toBe
(
'
STATUS_DESC
'
);
expect
(
findStatusColumnHeader
().
attributes
(
'
aria-sort
'
)).
toBe
(
'
descending
'
);
expect
(
findStatusColumnHeader
().
attributes
(
'
aria-sort
'
)).
toBe
(
'
descending
'
);
findStatusColumnHeader
().
trigger
(
'
click
'
);
findStatusColumnHeader
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
sort
).
toBe
(
'
STATUS_ASC
'
);
expect
(
wrapper
.
vm
.
sort
).
toBe
(
'
STATUS_ASC
'
);
expect
(
findStatusColumnHeader
().
attributes
(
'
aria-sort
'
)).
toBe
(
'
ascending
'
);
expect
(
findStatusColumnHeader
().
attributes
(
'
aria-sort
'
)).
toBe
(
'
ascending
'
);
...
@@ -270,7 +271,7 @@ describe('AlertsList component', () => {
...
@@ -270,7 +271,7 @@ describe('AlertsList component', () => {
wrapper
.
setData
({
wrapper
.
setData
({
errored
:
true
,
errored
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findErrorAlert
().
exists
()).
toBe
(
true
);
expect
(
findErrorAlert
().
exists
()).
toBe
(
true
);
expect
(
findUnconfiguredAlert
().
exists
()).
toBe
(
false
);
expect
(
findUnconfiguredAlert
().
exists
()).
toBe
(
false
);
});
});
...
@@ -281,7 +282,7 @@ describe('AlertsList component', () => {
...
@@ -281,7 +282,7 @@ describe('AlertsList component', () => {
wrapper
.
setData
({
wrapper
.
setData
({
isErrorAlertDismissed
:
true
,
isErrorAlertDismissed
:
true
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findUnconfiguredAlert
().
exists
()).
toBe
(
false
);
expect
(
findUnconfiguredAlert
().
exists
()).
toBe
(
false
);
});
});
});
});
...
@@ -296,7 +297,7 @@ describe('AlertsList component', () => {
...
@@ -296,7 +297,7 @@ describe('AlertsList component', () => {
}),
}),
});
});
findGlIntersectionObserver
().
vm
.
$emit
(
'
appear
'
);
findGlIntersectionObserver
().
vm
.
$emit
(
'
appear
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
$apollo
.
queries
.
alerts
.
fetchMore
).
toHaveBeenCalledTimes
(
1
);
expect
(
wrapper
.
vm
.
$apollo
.
queries
.
alerts
.
fetchMore
).
toHaveBeenCalledTimes
(
1
);
});
});
});
});
...
@@ -315,7 +316,7 @@ describe('AlertsList component', () => {
...
@@ -315,7 +316,7 @@ describe('AlertsList component', () => {
it
(
'
does refetch the alerts when an alert status has changed
'
,
async
()
=>
{
it
(
'
does refetch the alerts when an alert status has changed
'
,
async
()
=>
{
expect
(
refetchSpy
).
toHaveBeenCalledTimes
(
0
);
expect
(
refetchSpy
).
toHaveBeenCalledTimes
(
0
);
findStatusColumn
().
vm
.
$emit
(
'
alert-update
'
);
findStatusColumn
().
vm
.
$emit
(
'
alert-update
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
refetchSpy
).
toHaveBeenCalledTimes
(
1
);
expect
(
refetchSpy
).
toHaveBeenCalledTimes
(
1
);
});
});
...
@@ -323,7 +324,7 @@ describe('AlertsList component', () => {
...
@@ -323,7 +324,7 @@ describe('AlertsList component', () => {
const
error
=
'
Error.
'
;
const
error
=
'
Error.
'
;
expect
(
findErrorAlert
().
exists
()).
toBe
(
false
);
expect
(
findErrorAlert
().
exists
()).
toBe
(
false
);
findStatusColumn
().
vm
.
$emit
(
'
alert-error
'
,
error
);
findStatusColumn
().
vm
.
$emit
(
'
alert-error
'
,
error
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findErrorAlert
().
exists
()).
toBe
(
true
);
expect
(
findErrorAlert
().
exists
()).
toBe
(
true
);
expect
(
findErrorAlert
().
text
()).
toBe
(
error
);
expect
(
findErrorAlert
().
text
()).
toBe
(
error
);
});
});
...
...
ee/spec/frontend/threat_monitoring/components/instance_project_selector_spec.js
View file @
6979e878
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
InstanceProjectSelector
from
'
ee/threat_monitoring/components/instance_project_selector.vue
'
;
import
InstanceProjectSelector
from
'
ee/threat_monitoring/components/instance_project_selector.vue
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
...
@@ -141,7 +141,7 @@ describe('InstanceProjectSelector Component', () => {
...
@@ -141,7 +141,7 @@ describe('InstanceProjectSelector Component', () => {
it
(
'
notifies project selector of search error
'
,
async
()
=>
{
it
(
'
notifies project selector of search error
'
,
async
()
=>
{
querySpy
=
jest
.
fn
().
mockResolvedValue
(
mockGetUsersProjects
.
error
);
querySpy
=
jest
.
fn
().
mockResolvedValue
(
mockGetUsersProjects
.
error
);
createWrapper
({
queryResolver
:
querySpy
});
createWrapper
({
queryResolver
:
querySpy
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
findProjectSelector
().
vm
.
$emit
(
'
searched
'
,
'
abc
'
);
findProjectSelector
().
vm
.
$emit
(
'
searched
'
,
'
abc
'
);
await
waitForPromises
();
await
waitForPromises
();
expect
(
findProjectSelector
().
props
()).
toStrictEqual
({
expect
(
findProjectSelector
().
props
()).
toStrictEqual
({
...
@@ -153,7 +153,7 @@ describe('InstanceProjectSelector Component', () => {
...
@@ -153,7 +153,7 @@ describe('InstanceProjectSelector Component', () => {
it
(
'
notifies project selector of no results
'
,
async
()
=>
{
it
(
'
notifies project selector of no results
'
,
async
()
=>
{
querySpy
=
jest
.
fn
().
mockResolvedValue
(
mockGetUsersProjects
.
empty
);
querySpy
=
jest
.
fn
().
mockResolvedValue
(
mockGetUsersProjects
.
empty
);
createWrapper
({
queryResolver
:
querySpy
});
createWrapper
({
queryResolver
:
querySpy
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
findProjectSelector
().
vm
.
$emit
(
'
searched
'
,
'
abc
'
);
findProjectSelector
().
vm
.
$emit
(
'
searched
'
,
'
abc
'
);
await
waitForPromises
();
await
waitForPromises
();
expect
(
findProjectSelector
().
props
()).
toStrictEqual
({
expect
(
findProjectSelector
().
props
()).
toStrictEqual
({
...
...
ee/spec/frontend/threat_monitoring/components/policies/no_policies_empty_state_spec.js
View file @
6979e878
import
{
nextTick
}
from
'
vue
'
;
import
NoPoliciesEmptyState
from
'
ee/threat_monitoring/components/policies/no_policies_empty_state.vue
'
;
import
NoPoliciesEmptyState
from
'
ee/threat_monitoring/components/policies/no_policies_empty_state.vue
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
...
@@ -32,7 +33,7 @@ describe('NoPoliciesEmptyState component', () => {
...
@@ -32,7 +33,7 @@ describe('NoPoliciesEmptyState component', () => {
${
'
does display the empty list state
'
}
|
${
findEmptyListState
}
|
${
false
}
|
${()
=>
factory
(
true
)}
${
'
does display the empty list state
'
}
|
${
findEmptyListState
}
|
${
false
}
|
${()
=>
factory
(
true
)}
`
(
'
$title
'
,
async
({
factoryFn
,
findComponent
,
state
})
=>
{
`
(
'
$title
'
,
async
({
factoryFn
,
findComponent
,
state
})
=>
{
factoryFn
();
factoryFn
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findComponent
().
exists
()).
toBe
(
state
);
expect
(
findComponent
().
exists
()).
toBe
(
state
);
});
});
});
});
ee/spec/frontend/threat_monitoring/components/policies/policies_app_spec.js
View file @
6979e878
import
{
nextTick
}
from
'
vue
'
;
import
PoliciesApp
from
'
ee/threat_monitoring/components/policies/policies_app.vue
'
;
import
PoliciesApp
from
'
ee/threat_monitoring/components/policies/policies_app.vue
'
;
import
PoliciesHeader
from
'
ee/threat_monitoring/components/policies/policies_header.vue
'
;
import
PoliciesHeader
from
'
ee/threat_monitoring/components/policies/policies_header.vue
'
;
import
PoliciesList
from
'
ee/threat_monitoring/components/policies/policies_list.vue
'
;
import
PoliciesList
from
'
ee/threat_monitoring/components/policies/policies_list.vue
'
;
...
@@ -35,7 +36,7 @@ describe('Policies App', () => {
...
@@ -35,7 +36,7 @@ describe('Policies App', () => {
async
({
findFn
})
=>
{
async
({
findFn
})
=>
{
expect
(
findPoliciesList
().
props
(
'
shouldUpdatePolicyList
'
)).
toBe
(
false
);
expect
(
findPoliciesList
().
props
(
'
shouldUpdatePolicyList
'
)).
toBe
(
false
);
findFn
().
vm
.
$emit
(
'
update-policy-list
'
,
true
);
findFn
().
vm
.
$emit
(
'
update-policy-list
'
,
true
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findPoliciesList
().
props
(
'
shouldUpdatePolicyList
'
)).
toBe
(
true
);
expect
(
findPoliciesList
().
props
(
'
shouldUpdatePolicyList
'
)).
toBe
(
true
);
},
},
);
);
...
...
ee/spec/frontend/threat_monitoring/components/policies/policies_header_spec.js
View file @
6979e878
import
{
GlAlert
,
GlButton
,
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
GlAlert
,
GlButton
,
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
NEW_POLICY_BUTTON_TEXT
}
from
'
ee/threat_monitoring/components/constants
'
;
import
{
NEW_POLICY_BUTTON_TEXT
}
from
'
ee/threat_monitoring/components/constants
'
;
import
PoliciesHeader
from
'
ee/threat_monitoring/components/policies/policies_header.vue
'
;
import
PoliciesHeader
from
'
ee/threat_monitoring/components/policies/policies_header.vue
'
;
import
ScanNewPolicyModal
from
'
ee/threat_monitoring/components/policies/scan_new_policy_modal.vue
'
;
import
ScanNewPolicyModal
from
'
ee/threat_monitoring/components/policies/scan_new_policy_modal.vue
'
;
...
@@ -24,7 +25,7 @@ describe('Policies Header Component', () => {
...
@@ -24,7 +25,7 @@ describe('Policies Header Component', () => {
text
:
projectLinkSuccessText
,
text
:
projectLinkSuccessText
,
variant
:
'
success
'
,
variant
:
'
success
'
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
const
createWrapper
=
({
provide
}
=
{})
=>
{
const
createWrapper
=
({
provide
}
=
{})
=>
{
...
@@ -98,7 +99,7 @@ describe('Policies Header Component', () => {
...
@@ -98,7 +99,7 @@ describe('Policies Header Component', () => {
it
(
'
hides the previous alert when scan new modal policy is processing a new link
'
,
async
()
=>
{
it
(
'
hides the previous alert when scan new modal policy is processing a new link
'
,
async
()
=>
{
findScanNewPolicyModal
().
vm
.
$emit
(
'
updating-project
'
);
findScanNewPolicyModal
().
vm
.
$emit
(
'
updating-project
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findAlert
().
exists
()).
toBe
(
false
);
expect
(
findAlert
().
exists
()).
toBe
(
false
);
});
});
});
});
...
...
ee/spec/frontend/threat_monitoring/components/policies/policies_list_spec.js
View file @
6979e878
import
{
GlTable
,
GlDrawer
}
from
'
@gitlab/ui
'
;
import
{
GlTable
,
GlDrawer
}
from
'
@gitlab/ui
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
{
merge
}
from
'
lodash
'
;
import
{
merge
}
from
'
lodash
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
POLICY_TYPE_OPTIONS
}
from
'
ee/threat_monitoring/components/constants
'
;
import
{
POLICY_TYPE_OPTIONS
}
from
'
ee/threat_monitoring/components/constants
'
;
...
@@ -225,7 +225,7 @@ describe('PoliciesList component', () => {
...
@@ -225,7 +225,7 @@ describe('PoliciesList component', () => {
${
'
scan result
'
}
|
${
POLICY_TYPE_OPTIONS
.
POLICY_TYPE_SCAN_RESULT
}
|
${[
POLICY_TYPE_OPTIONS
.
POLICY_TYPE_NETWORK
,
POLICY_TYPE_OPTIONS
.
POLICY_TYPE_SCAN_EXECUTION
]}
${
'
scan result
'
}
|
${
POLICY_TYPE_OPTIONS
.
POLICY_TYPE_SCAN_RESULT
}
|
${[
POLICY_TYPE_OPTIONS
.
POLICY_TYPE_NETWORK
,
POLICY_TYPE_OPTIONS
.
POLICY_TYPE_SCAN_EXECUTION
]}
`
(
'
policies filtered by $description type
'
,
async
({
filterBy
,
hiddenTypes
})
=>
{
`
(
'
policies filtered by $description type
'
,
async
({
filterBy
,
hiddenTypes
})
=>
{
findPolicyTypeFilter
().
vm
.
$emit
(
'
input
'
,
filterBy
.
value
);
findPolicyTypeFilter
().
vm
.
$emit
(
'
input
'
,
filterBy
.
value
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findPoliciesTable
().
text
()).
toContain
(
filterBy
.
text
);
expect
(
findPoliciesTable
().
text
()).
toContain
(
filterBy
.
text
);
hiddenTypes
.
forEach
((
hiddenType
)
=>
{
hiddenTypes
.
forEach
((
hiddenType
)
=>
{
...
@@ -237,16 +237,16 @@ describe('PoliciesList component', () => {
...
@@ -237,16 +237,16 @@ describe('PoliciesList component', () => {
expect
(
scanExecutionPoliciesSpy
).
toHaveBeenCalledTimes
(
1
);
expect
(
scanExecutionPoliciesSpy
).
toHaveBeenCalledTimes
(
1
);
expect
(
wrapper
.
emitted
(
'
update-policy-list
'
)).
toBeUndefined
();
expect
(
wrapper
.
emitted
(
'
update-policy-list
'
)).
toBeUndefined
();
wrapper
.
setProps
({
shouldUpdatePolicyList
:
true
});
wrapper
.
setProps
({
shouldUpdatePolicyList
:
true
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
(
'
update-policy-list
'
)).
toStrictEqual
([[
false
]]);
expect
(
wrapper
.
emitted
(
'
update-policy-list
'
)).
toStrictEqual
([[
false
]]);
expect
(
scanExecutionPoliciesSpy
).
toHaveBeenCalledTimes
(
2
);
expect
(
scanExecutionPoliciesSpy
).
toHaveBeenCalledTimes
(
2
);
});
});
it
(
'
does not emit `update-policy-list` or refetch scan execution policies on `shouldUpdatePolicyList` change to `false`
'
,
async
()
=>
{
it
(
'
does not emit `update-policy-list` or refetch scan execution policies on `shouldUpdatePolicyList` change to `false`
'
,
async
()
=>
{
wrapper
.
setProps
({
shouldUpdatePolicyList
:
true
});
wrapper
.
setProps
({
shouldUpdatePolicyList
:
true
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
wrapper
.
setProps
({
shouldUpdatePolicyList
:
false
});
wrapper
.
setProps
({
shouldUpdatePolicyList
:
false
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
(
'
update-policy-list
'
)).
toStrictEqual
([[
false
]]);
expect
(
wrapper
.
emitted
(
'
update-policy-list
'
)).
toStrictEqual
([[
false
]]);
expect
(
scanExecutionPoliciesSpy
).
toHaveBeenCalledTimes
(
2
);
expect
(
scanExecutionPoliciesSpy
).
toHaveBeenCalledTimes
(
2
);
});
});
...
...
ee/spec/frontend/threat_monitoring/components/policies/scan_new_policy_modal_spec.js
View file @
6979e878
import
{
GlDropdown
,
GlModal
,
GlAlert
}
from
'
@gitlab/ui
'
;
import
{
GlDropdown
,
GlModal
,
GlAlert
}
from
'
@gitlab/ui
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
InstanceProjectSelector
from
'
ee/threat_monitoring/components/instance_project_selector.vue
'
;
import
InstanceProjectSelector
from
'
ee/threat_monitoring/components/instance_project_selector.vue
'
;
import
ScanNewPolicyModal
from
'
ee/threat_monitoring/components/policies/scan_new_policy_modal.vue
'
;
import
ScanNewPolicyModal
from
'
ee/threat_monitoring/components/policies/scan_new_policy_modal.vue
'
;
...
@@ -115,7 +115,7 @@ describe('ScanNewPolicyModal Component', () => {
...
@@ -115,7 +115,7 @@ describe('ScanNewPolicyModal Component', () => {
expect
(
findInstanceProjectSelector
().
props
(
'
selectedProjects
'
)[
0
].
name
).
toBe
(
'
Test 1
'
);
expect
(
findInstanceProjectSelector
().
props
(
'
selectedProjects
'
)[
0
].
name
).
toBe
(
'
Test 1
'
);
// should restore the previous state when action is not submitted
// should restore the previous state when action is not submitted
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findInstanceProjectSelector
().
props
(
'
selectedProjects
'
)[
0
].
name
).
toBeUndefined
();
expect
(
findInstanceProjectSelector
().
props
(
'
selectedProjects
'
)[
0
].
name
).
toBeUndefined
();
});
});
...
@@ -139,7 +139,7 @@ describe('ScanNewPolicyModal Component', () => {
...
@@ -139,7 +139,7 @@ describe('ScanNewPolicyModal Component', () => {
// When we click on the delete button, the component should display a warning
// When we click on the delete button, the component should display a warning
findUnlinkButton
().
trigger
(
'
click
'
);
findUnlinkButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findByText
(
wrapper
.
vm
.
$options
.
i18n
.
unlinkWarning
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findByText
(
wrapper
.
vm
.
$options
.
i18n
.
unlinkWarning
).
exists
()).
toBe
(
true
);
expect
(
findModal
().
attributes
(
'
ok-disabled
'
)).
toBeUndefined
();
expect
(
findModal
().
attributes
(
'
ok-disabled
'
)).
toBeUndefined
();
...
...
ee/spec/frontend/threat_monitoring/components/policy_editor/network_policy/network_policy_editor_spec.js
View file @
6979e878
import
{
GlEmptyState
,
GlFormCheckbox
,
GlFormGroup
}
from
'
@gitlab/ui
'
;
import
{
GlEmptyState
,
GlFormCheckbox
,
GlFormGroup
}
from
'
@gitlab/ui
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
EDITOR_MODE_YAML
}
from
'
ee/threat_monitoring/components/policy_editor/constants
'
;
import
{
EDITOR_MODE_YAML
}
from
'
ee/threat_monitoring/components/policy_editor/constants
'
;
import
DimDisableContainer
from
'
ee/threat_monitoring/components/policy_editor/dim_disable_container.vue
'
;
import
DimDisableContainer
from
'
ee/threat_monitoring/components/policy_editor/dim_disable_container.vue
'
;
import
{
import
{
...
@@ -357,7 +358,7 @@ describe('NetworkPolicyEditor component', () => {
...
@@ -357,7 +358,7 @@ describe('NetworkPolicyEditor component', () => {
it
(
'
it does not redirect
'
,
async
()
=>
{
it
(
'
it does not redirect
'
,
async
()
=>
{
findPolicyEditorLayout
().
vm
.
$emit
(
'
save-policy
'
);
findPolicyEditorLayout
().
vm
.
$emit
(
'
save-policy
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
redirectTo
).
not
.
toHaveBeenCalledWith
(
'
/threat-monitoring
'
);
expect
(
redirectTo
).
not
.
toHaveBeenCalledWith
(
'
/threat-monitoring
'
);
});
});
});
});
...
...
ee/spec/frontend/threat_monitoring/components/policy_editor/network_policy/policy_rule_builder_spec.js
View file @
6979e878
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
import
{
RuleDirectionOutbound
,
RuleDirectionOutbound
,
EndpointMatchModeAny
,
EndpointMatchModeAny
,
...
@@ -54,13 +55,13 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -54,13 +55,13 @@ describe('PolicyRuleBuilder component', () => {
it
(
'
updates rule direction upon selecting
'
,
async
()
=>
{
it
(
'
updates rule direction upon selecting
'
,
async
()
=>
{
selectFirstOption
(
"
[id='direction']
"
);
selectFirstOption
(
"
[id='direction']
"
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
rule
.
direction
).
toEqual
(
RuleDirectionOutbound
);
expect
(
rule
.
direction
).
toEqual
(
RuleDirectionOutbound
);
});
});
it
(
'
emits endpoint-match-mode-change upon selecting
'
,
async
()
=>
{
it
(
'
emits endpoint-match-mode-change upon selecting
'
,
async
()
=>
{
selectFirstOption
(
"
[data-testid='endpoint-match-mode']
"
);
selectFirstOption
(
"
[data-testid='endpoint-match-mode']
"
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
event
=
wrapper
.
emitted
()[
'
endpoint-match-mode-change
'
];
const
event
=
wrapper
.
emitted
()[
'
endpoint-match-mode-change
'
];
expect
(
event
.
length
).
toEqual
(
2
);
expect
(
event
.
length
).
toEqual
(
2
);
expect
(
event
[
0
]).
toEqual
([
EndpointMatchModeLabel
]);
expect
(
event
[
0
]).
toEqual
([
EndpointMatchModeLabel
]);
...
@@ -86,7 +87,7 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -86,7 +87,7 @@ describe('PolicyRuleBuilder component', () => {
it
(
'
emits endpoint-labels-change on change
'
,
async
()
=>
{
it
(
'
emits endpoint-labels-change on change
'
,
async
()
=>
{
const
input
=
findEndpointLabels
();
const
input
=
findEndpointLabels
();
input
.
setValue
(
'
foo:bar
'
);
input
.
setValue
(
'
foo:bar
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
event
=
wrapper
.
emitted
()[
'
endpoint-labels-change
'
];
const
event
=
wrapper
.
emitted
()[
'
endpoint-labels-change
'
];
expect
(
event
.
length
).
toEqual
(
1
);
expect
(
event
.
length
).
toEqual
(
1
);
expect
(
event
[
0
]).
toEqual
([
'
foo:bar
'
]);
expect
(
event
[
0
]).
toEqual
([
'
foo:bar
'
]);
...
@@ -95,7 +96,7 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -95,7 +96,7 @@ describe('PolicyRuleBuilder component', () => {
it
(
'
emits rule-type-change upon selecting
'
,
async
()
=>
{
it
(
'
emits rule-type-change upon selecting
'
,
async
()
=>
{
selectFirstOption
(
"
[id='ruleMode']
"
);
selectFirstOption
(
"
[id='ruleMode']
"
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
event
=
wrapper
.
emitted
()[
'
rule-type-change
'
];
const
event
=
wrapper
.
emitted
()[
'
rule-type-change
'
];
expect
(
event
.
length
).
toEqual
(
2
);
expect
(
event
.
length
).
toEqual
(
2
);
expect
(
event
[
0
]).
toEqual
([
RuleTypeEntity
]);
expect
(
event
[
0
]).
toEqual
([
RuleTypeEntity
]);
...
@@ -131,7 +132,7 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -131,7 +132,7 @@ describe('PolicyRuleBuilder component', () => {
el
.
findAll
(
'
button
'
)
el
.
findAll
(
'
button
'
)
.
filter
((
e
)
=>
e
.
text
()
===
'
host
'
)
.
filter
((
e
)
=>
e
.
text
()
===
'
host
'
)
.
trigger
(
'
click
'
);
.
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
rule
.
entities
).
toEqual
([
'
host
'
]);
expect
(
rule
.
entities
).
toEqual
([
'
host
'
]);
});
});
});
});
...
@@ -153,7 +154,7 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -153,7 +154,7 @@ describe('PolicyRuleBuilder component', () => {
const
el
=
findRuleCIDR
();
const
el
=
findRuleCIDR
();
el
.
setValue
(
'
0.0.0.0/24
'
);
el
.
setValue
(
'
0.0.0.0/24
'
);
el
.
trigger
(
'
change
'
);
el
.
trigger
(
'
change
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
rule
.
cidr
).
toEqual
(
'
0.0.0.0/24
'
);
expect
(
rule
.
cidr
).
toEqual
(
'
0.0.0.0/24
'
);
});
});
});
});
...
@@ -175,14 +176,14 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -175,14 +176,14 @@ describe('PolicyRuleBuilder component', () => {
const
el
=
findRuleFQDN
();
const
el
=
findRuleFQDN
();
el
.
setValue
(
'
some-service.com
'
);
el
.
setValue
(
'
some-service.com
'
);
el
.
trigger
(
'
change
'
);
el
.
trigger
(
'
change
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
rule
.
fqdn
).
toEqual
(
'
some-service.com
'
);
expect
(
rule
.
fqdn
).
toEqual
(
'
some-service.com
'
);
});
});
});
});
it
(
'
updates port match mode upon selecting
'
,
async
()
=>
{
it
(
'
updates port match mode upon selecting
'
,
async
()
=>
{
selectFirstOption
(
"
[id='portMatch']
"
);
selectFirstOption
(
"
[id='portMatch']
"
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
rule
.
portMatchMode
).
toEqual
(
PortMatchModePortProtocol
);
expect
(
rule
.
portMatchMode
).
toEqual
(
PortMatchModePortProtocol
);
});
});
...
@@ -203,7 +204,7 @@ describe('PolicyRuleBuilder component', () => {
...
@@ -203,7 +204,7 @@ describe('PolicyRuleBuilder component', () => {
it
(
'
updates ports
'
,
async
()
=>
{
it
(
'
updates ports
'
,
async
()
=>
{
const
input
=
findPorts
();
const
input
=
findPorts
();
input
.
setValue
(
'
80/tcp
'
);
input
.
setValue
(
'
80/tcp
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
rule
.
ports
).
toEqual
(
'
80/tcp
'
);
expect
(
rule
.
ports
).
toEqual
(
'
80/tcp
'
);
});
});
});
});
...
...
ee/spec/frontend/threat_monitoring/components/policy_editor/policy_alert_picker_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
PolicyAlertPicker
from
'
ee/threat_monitoring/components/policy_editor/policy_alert_picker.vue
'
;
import
PolicyAlertPicker
from
'
ee/threat_monitoring/components/policy_editor/policy_alert_picker.vue
'
;
import
getAgentCount
from
'
ee/threat_monitoring/graphql/queries/get_agent_count.query.graphql
'
;
import
getAgentCount
from
'
ee/threat_monitoring/graphql/queries/get_agent_count.query.graphql
'
;
...
@@ -42,7 +42,7 @@ describe('PolicyAlertPicker component', () => {
...
@@ -42,7 +42,7 @@ describe('PolicyAlertPicker component', () => {
},
},
}),
}),
);
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
afterEach
(()
=>
{
afterEach
(()
=>
{
...
...
ee/spec/frontend/threat_monitoring/components/policy_editor/policy_editor_spec.js
View file @
6979e878
import
{
GlAlert
,
GlFormSelect
}
from
'
@gitlab/ui
'
;
import
{
GlAlert
,
GlFormSelect
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
POLICY_TYPE_COMPONENT_OPTIONS
}
from
'
ee/threat_monitoring/components/constants
'
;
import
{
POLICY_TYPE_COMPONENT_OPTIONS
}
from
'
ee/threat_monitoring/components/constants
'
;
import
EnvironmentPicker
from
'
ee/threat_monitoring/components/environment_picker.vue
'
;
import
EnvironmentPicker
from
'
ee/threat_monitoring/components/environment_picker.vue
'
;
import
NetworkPolicyEditor
from
'
ee/threat_monitoring/components/policy_editor/network_policy/network_policy_editor.vue
'
;
import
NetworkPolicyEditor
from
'
ee/threat_monitoring/components/policy_editor/network_policy/network_policy_editor.vue
'
;
...
@@ -66,7 +67,7 @@ describe('PolicyEditor component', () => {
...
@@ -66,7 +67,7 @@ describe('PolicyEditor component', () => {
it
(
'
shows an alert when "error" is emitted from the component
'
,
async
()
=>
{
it
(
'
shows an alert when "error" is emitted from the component
'
,
async
()
=>
{
const
errorMessage
=
'
test
'
;
const
errorMessage
=
'
test
'
;
findNeworkPolicyEditor
().
vm
.
$emit
(
'
error
'
,
errorMessage
);
findNeworkPolicyEditor
().
vm
.
$emit
(
'
error
'
,
errorMessage
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
alert
=
findAlert
();
const
alert
=
findAlert
();
expect
(
alert
.
exists
()).
toBe
(
true
);
expect
(
alert
.
exists
()).
toBe
(
true
);
expect
(
alert
.
text
()).
toBe
(
errorMessage
);
expect
(
alert
.
text
()).
toBe
(
errorMessage
);
...
@@ -82,7 +83,7 @@ describe('PolicyEditor component', () => {
...
@@ -82,7 +83,7 @@ describe('PolicyEditor component', () => {
async
({
findComponent
,
option
,
policyType
})
=>
{
async
({
findComponent
,
option
,
policyType
})
=>
{
const
formSelect
=
findFormSelect
();
const
formSelect
=
findFormSelect
();
formSelect
.
vm
.
$emit
(
'
change
'
,
policyType
);
formSelect
.
vm
.
$emit
(
'
change
'
,
policyType
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
component
=
findComponent
();
const
component
=
findComponent
();
expect
(
formSelect
.
attributes
(
'
value
'
)).
toBe
(
option
.
value
);
expect
(
formSelect
.
attributes
(
'
value
'
)).
toBe
(
option
.
value
);
expect
(
component
.
exists
()).
toBe
(
true
);
expect
(
component
.
exists
()).
toBe
(
true
);
...
@@ -91,11 +92,11 @@ describe('PolicyEditor component', () => {
...
@@ -91,11 +92,11 @@ describe('PolicyEditor component', () => {
);
);
describe
(
'
with scan_result_policy feature flag disabled
'
,
()
=>
{
describe
(
'
with scan_result_policy feature flag disabled
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
factory
({
provide
:
{
glFeatures
:
{
scanResultPolicy
:
false
}
}
});
factory
({
provide
:
{
glFeatures
:
{
scanResultPolicy
:
false
}
}
});
const
formSelect
=
findFormSelect
();
const
formSelect
=
findFormSelect
();
formSelect
.
vm
.
$emit
(
'
change
'
,
POLICY_TYPE_COMPONENT_OPTIONS
.
scanResult
.
value
);
formSelect
.
vm
.
$emit
(
'
change
'
,
POLICY_TYPE_COMPONENT_OPTIONS
.
scanResult
.
value
);
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
does not render scan result policy
'
,
()
=>
{
it
(
'
does not render scan result policy
'
,
()
=>
{
...
@@ -124,7 +125,7 @@ describe('PolicyEditor component', () => {
...
@@ -124,7 +125,7 @@ describe('PolicyEditor component', () => {
propsData
:
{
existingPolicy
},
propsData
:
{
existingPolicy
},
provide
:
{
policyType
,
glFeatures
:
{
scanResultPolicy
:
true
}
},
provide
:
{
policyType
,
glFeatures
:
{
scanResultPolicy
:
true
}
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
formSelect
=
findFormSelect
();
const
formSelect
=
findFormSelect
();
expect
(
formSelect
.
exists
()).
toBe
(
true
);
expect
(
formSelect
.
exists
()).
toBe
(
true
);
expect
(
formSelect
.
attributes
(
'
value
'
)).
toBe
(
option
.
value
);
expect
(
formSelect
.
attributes
(
'
value
'
)).
toBe
(
option
.
value
);
...
...
ee/spec/frontend/threat_monitoring/components/policy_editor/scan_execution_policy/scan_execution_policy_editor_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlEmptyState
}
from
'
@gitlab/ui
'
;
import
{
GlEmptyState
}
from
'
@gitlab/ui
'
;
import
{
nextTick
}
from
'
vue
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
PolicyEditorLayout
from
'
ee/threat_monitoring/components/policy_editor/policy_editor_layout.vue
'
;
import
PolicyEditorLayout
from
'
ee/threat_monitoring/components/policy_editor/policy_editor_layout.vue
'
;
import
{
import
{
...
@@ -97,7 +98,7 @@ describe('ScanExecutionPolicyEditor', () => {
...
@@ -97,7 +98,7 @@ describe('ScanExecutionPolicyEditor', () => {
describe
(
'
default
'
,
()
=>
{
describe
(
'
default
'
,
()
=>
{
it
(
'
updates the policy yaml when "update-yaml" is emitted
'
,
async
()
=>
{
it
(
'
updates the policy yaml when "update-yaml" is emitted
'
,
async
()
=>
{
factory
();
factory
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
newManifest
=
'
new yaml!
'
;
const
newManifest
=
'
new yaml!
'
;
expect
(
findPolicyEditorLayout
().
attributes
(
'
yamleditorvalue
'
)).
toBe
(
expect
(
findPolicyEditorLayout
().
attributes
(
'
yamleditorvalue
'
)).
toBe
(
DEFAULT_SCAN_EXECUTION_POLICY
,
DEFAULT_SCAN_EXECUTION_POLICY
,
...
@@ -115,7 +116,7 @@ describe('ScanExecutionPolicyEditor', () => {
...
@@ -115,7 +116,7 @@ describe('ScanExecutionPolicyEditor', () => {
'
navigates to the new merge request when "modifyPolicy" is emitted $status
'
,
'
navigates to the new merge request when "modifyPolicy" is emitted $status
'
,
async
({
action
,
event
,
factoryFn
,
yamlEditorValue
,
currentlyAssignedPolicyProject
})
=>
{
async
({
action
,
event
,
factoryFn
,
yamlEditorValue
,
currentlyAssignedPolicyProject
})
=>
{
factoryFn
();
factoryFn
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
findPolicyEditorLayout
().
vm
.
$emit
(
event
);
findPolicyEditorLayout
().
vm
.
$emit
(
event
);
await
waitForPromises
();
await
waitForPromises
();
expect
(
modifyPolicy
).
toHaveBeenCalledTimes
(
1
);
expect
(
modifyPolicy
).
toHaveBeenCalledTimes
(
1
);
...
@@ -129,7 +130,7 @@ describe('ScanExecutionPolicyEditor', () => {
...
@@ -129,7 +130,7 @@ describe('ScanExecutionPolicyEditor', () => {
projectPath
:
defaultProjectPath
,
projectPath
:
defaultProjectPath
,
yamlEditorValue
,
yamlEditorValue
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
visitUrl
).
toHaveBeenCalled
();
expect
(
visitUrl
).
toHaveBeenCalled
();
expect
(
visitUrl
).
toHaveBeenCalledWith
(
expect
(
visitUrl
).
toHaveBeenCalledWith
(
`/
${
currentlyAssignedPolicyProject
.
fullPath
}
/-/merge_requests/2`
,
`/
${
currentlyAssignedPolicyProject
.
fullPath
}
/-/merge_requests/2`
,
...
@@ -141,7 +142,7 @@ describe('ScanExecutionPolicyEditor', () => {
...
@@ -141,7 +142,7 @@ describe('ScanExecutionPolicyEditor', () => {
describe
(
'
when a user is not an owner of the project
'
,
()
=>
{
describe
(
'
when a user is not an owner of the project
'
,
()
=>
{
it
(
'
displays the empty state with the appropriate properties
'
,
async
()
=>
{
it
(
'
displays the empty state with the appropriate properties
'
,
async
()
=>
{
factory
({
provide
:
{
disableScanExecutionUpdate
:
true
}
});
factory
({
provide
:
{
disableScanExecutionUpdate
:
true
}
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findEmptyState
().
props
()).
toMatchObject
({
expect
(
findEmptyState
().
props
()).
toMatchObject
({
primaryButtonLink
:
scanExecutionDocumentationPath
,
primaryButtonLink
:
scanExecutionDocumentationPath
,
svgPath
:
policyEditorEmptyStateSvgPath
,
svgPath
:
policyEditorEmptyStateSvgPath
,
...
...
ee/spec/frontend/threat_monitoring/components/policy_yaml_editor_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
PolicyYamlEditor
from
'
ee/threat_monitoring/components/policy_yaml_editor.vue
'
;
import
PolicyYamlEditor
from
'
ee/threat_monitoring/components/policy_yaml_editor.vue
'
;
import
SourceEditor
from
'
~/vue_shared/components/source_editor.vue
'
;
import
SourceEditor
from
'
~/vue_shared/components/source_editor.vue
'
;
...
@@ -42,7 +43,7 @@ describe('PolicyYamlEditor component', () => {
...
@@ -42,7 +43,7 @@ describe('PolicyYamlEditor component', () => {
it
(
"
emits input event on editor's input
"
,
async
()
=>
{
it
(
"
emits input event on editor's input
"
,
async
()
=>
{
const
editor
=
findEditor
();
const
editor
=
findEditor
();
editor
.
vm
.
$emit
(
'
input
'
);
editor
.
vm
.
$emit
(
'
input
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
emitted
().
input
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
input
).
toBeTruthy
();
});
});
});
});
ee/spec/frontend/threat_monitoring/components/statistics_history_spec.js
View file @
6979e878
import
{
GlAreaChart
}
from
'
@gitlab/ui/dist/charts
'
;
import
{
GlAreaChart
}
from
'
@gitlab/ui/dist/charts
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
{
TOTAL_REQUESTS
,
ANOMALOUS_REQUESTS
}
from
'
ee/threat_monitoring/components/constants
'
;
import
{
TOTAL_REQUESTS
,
ANOMALOUS_REQUESTS
}
from
'
ee/threat_monitoring/components/constants
'
;
import
StatisticsHistory
from
'
ee/threat_monitoring/components/statistics_history.vue
'
;
import
StatisticsHistory
from
'
ee/threat_monitoring/components/statistics_history.vue
'
;
import
{
mockNominalHistory
,
mockAnomalousHistory
}
from
'
../mocks/mock_data
'
;
import
{
mockNominalHistory
,
mockAnomalousHistory
}
from
'
../mocks/mock_data
'
;
...
@@ -108,7 +108,7 @@ describe('StatisticsHistory component', () => {
...
@@ -108,7 +108,7 @@ describe('StatisticsHistory component', () => {
});
});
describe
(
'
chart tooltip
'
,
()
=>
{
describe
(
'
chart tooltip
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
const
mockParams
=
{
const
mockParams
=
{
seriesData
:
[
seriesData
:
[
{
{
...
@@ -140,7 +140,7 @@ describe('StatisticsHistory component', () => {
...
@@ -140,7 +140,7 @@ describe('StatisticsHistory component', () => {
},
},
});
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
renders the title and series data correctly
'
,
()
=>
{
it
(
'
renders the title and series data correctly
'
,
()
=>
{
...
...
ee/spec/frontend/trials/components/country_or_region_selector_spec.js
View file @
6979e878
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
...
@@ -73,7 +73,7 @@ describe('CountryOrRegionSelector', () => {
...
@@ -73,7 +73,7 @@ describe('CountryOrRegionSelector', () => {
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
countries
,
states
,
country
});
wrapper
.
setData
({
countries
,
states
,
country
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findFormInput
(
'
state
'
).
exists
()).
toBe
(
display
);
expect
(
findFormInput
(
'
state
'
).
exists
()).
toBe
(
display
);
});
});
...
...
ee/spec/frontend/usage_quotas/storage/components/collapsible_project_storage_detail_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
CollapsibleProjectStorageDetail
from
'
ee/usage_quotas/storage/components/collapsible_project_storage_detail.vue
'
;
import
CollapsibleProjectStorageDetail
from
'
ee/usage_quotas/storage/components/collapsible_project_storage_detail.vue
'
;
import
ProjectStorageDetail
from
'
ee/usage_quotas/storage/components/project_storage_detail.vue
'
;
import
ProjectStorageDetail
from
'
ee/usage_quotas/storage/components/project_storage_detail.vue
'
;
import
{
numberToHumanSize
}
from
'
~/lib/utils/number_utils
'
;
import
{
numberToHumanSize
}
from
'
~/lib/utils/number_utils
'
;
...
@@ -39,19 +40,17 @@ describe('CollapsibleProjectStorageDetail', () => {
...
@@ -39,19 +40,17 @@ describe('CollapsibleProjectStorageDetail', () => {
describe
(
'
toggle row
'
,
()
=>
{
describe
(
'
toggle row
'
,
()
=>
{
describe
(
'
on click
'
,
()
=>
{
describe
(
'
on click
'
,
()
=>
{
it
(
'
toggles isOpen
'
,
()
=>
{
it
(
'
toggles isOpen
'
,
async
()
=>
{
expect
(
findProjectStorageDetail
().
exists
()).
toBe
(
false
);
expect
(
findProjectStorageDetail
().
exists
()).
toBe
(
false
);
findTableRow
().
trigger
(
'
click
'
);
findTableRow
().
trigger
(
'
click
'
);
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
findProjectStorageDetail
().
exists
()).
toBe
(
true
);
expect
(
findProjectStorageDetail
().
exists
()).
toBe
(
true
);
findTableRow
().
trigger
(
'
click
'
);
findTableRow
().
trigger
(
'
click
'
);
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
findProjectStorageDetail
().
exists
()).
toBe
(
false
);
expect
(
findProjectStorageDetail
().
exists
()).
toBe
(
false
);
});
});
});
});
});
});
});
});
...
...
ee/spec/frontend/usage_quotas/storage/components/namespace_storage_app_spec.js
View file @
6979e878
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
NamespaceStorageApp
from
'
ee/usage_quotas/storage/components/namespace_storage_app.vue
'
;
import
NamespaceStorageApp
from
'
ee/usage_quotas/storage/components/namespace_storage_app.vue
'
;
import
CollapsibleProjectStorageDetail
from
'
ee/usage_quotas/storage/components/collapsible_project_storage_detail.vue
'
;
import
CollapsibleProjectStorageDetail
from
'
ee/usage_quotas/storage/components/collapsible_project_storage_detail.vue
'
;
import
ProjectList
from
'
ee/usage_quotas/storage/components/project_list.vue
'
;
import
ProjectList
from
'
ee/usage_quotas/storage/components/project_list.vue
'
;
...
@@ -79,7 +80,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -79,7 +80,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
namespaceData
,
namespace
:
namespaceData
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findAllComponents
(
CollapsibleProjectStorageDetail
)).
toHaveLength
(
3
);
expect
(
wrapper
.
findAllComponents
(
CollapsibleProjectStorageDetail
)).
toHaveLength
(
3
);
});
});
...
@@ -92,7 +93,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -92,7 +93,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
namespaceData
,
namespace
:
namespaceData
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
text
()).
toContain
(
formatUsageSize
(
namespaceData
.
limit
));
expect
(
wrapper
.
text
()).
toContain
(
formatUsageSize
(
namespaceData
.
limit
));
});
});
...
@@ -104,7 +105,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -104,7 +105,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
{
...
namespaceData
,
limit
:
0
},
namespace
:
{
...
namespaceData
,
limit
:
0
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
text
()).
not
.
toContain
(
formatUsageSize
(
0
));
expect
(
wrapper
.
text
()).
not
.
toContain
(
formatUsageSize
(
0
));
});
});
...
@@ -118,7 +119,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -118,7 +119,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
withRootStorageStatistics
,
namespace
:
withRootStorageStatistics
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findTotalUsage
().
text
()).
toContain
(
withRootStorageStatistics
.
totalUsage
);
expect
(
findTotalUsage
().
text
()).
toContain
(
withRootStorageStatistics
.
totalUsage
);
});
});
...
@@ -132,7 +133,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -132,7 +133,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
withRootStorageStatistics
,
namespace
:
withRootStorageStatistics
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findUsageGraph
().
exists
()).
toBe
(
true
);
expect
(
findUsageGraph
().
exists
()).
toBe
(
true
);
expect
(
findUsageStatistics
().
exists
()).
toBe
(
false
);
expect
(
findUsageStatistics
().
exists
()).
toBe
(
false
);
...
@@ -145,7 +146,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -145,7 +146,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
withRootStorageStatistics
,
namespace
:
withRootStorageStatistics
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findUsageStatistics
().
exists
()).
toBe
(
true
);
expect
(
findUsageStatistics
().
exists
()).
toBe
(
true
);
expect
(
findUsageGraph
().
exists
()).
toBe
(
false
);
expect
(
findUsageGraph
().
exists
()).
toBe
(
false
);
...
@@ -161,7 +162,7 @@ describe('NamespaceStorageApp', () => {
...
@@ -161,7 +162,7 @@ describe('NamespaceStorageApp', () => {
namespace
:
namespaceData
,
namespace
:
namespaceData
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findTotalUsage
().
text
()).
toContain
(
'
N/A
'
);
expect
(
findTotalUsage
().
text
()).
toContain
(
'
N/A
'
);
});
});
...
...
ee/spec/frontend/usage_quotas/storage/components/temporary_storage_increase_modal_spec.js
View file @
6979e878
import
{
GlModal
}
from
'
@gitlab/ui
'
;
import
{
GlModal
}
from
'
@gitlab/ui
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
TemporaryStorageIncreaseModal
from
'
ee/usage_quotas/storage/components/temporary_storage_increase_modal.vue
'
;
import
TemporaryStorageIncreaseModal
from
'
ee/usage_quotas/storage/components/temporary_storage_increase_modal.vue
'
;
const
TEST_LIMIT
=
'
8 bytes
'
;
const
TEST_LIMIT
=
'
8 bytes
'
;
...
@@ -18,9 +19,9 @@ describe('Temporary storage increase modal', () => {
...
@@ -18,9 +19,9 @@ describe('Temporary storage increase modal', () => {
});
});
};
};
const
findModal
=
()
=>
wrapper
.
findComponent
(
GlModal
);
const
findModal
=
()
=>
wrapper
.
findComponent
(
GlModal
);
const
showModal
=
()
=>
{
const
showModal
=
async
()
=>
{
findModal
().
vm
.
show
();
findModal
().
vm
.
show
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
const
findModalText
=
()
=>
document
.
body
.
innerText
;
const
findModalText
=
()
=>
document
.
body
.
innerText
;
...
...
ee/spec/frontend/vue_mr_widget/components/approvals/approvals_footer_spec.js
View file @
6979e878
import
{
GlButton
,
GlLoadingIcon
,
GlIcon
}
from
'
@gitlab/ui
'
;
import
{
GlButton
,
GlLoadingIcon
,
GlIcon
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
ApprovalsFooter
from
'
ee/vue_merge_request_widget/components/approvals/approvals_footer.vue
'
;
import
ApprovalsFooter
from
'
ee/vue_merge_request_widget/components/approvals/approvals_footer.vue
'
;
import
ApprovalsList
from
'
ee/vue_merge_request_widget/components/approvals/approvals_list.vue
'
;
import
ApprovalsList
from
'
ee/vue_merge_request_widget/components/approvals/approvals_list.vue
'
;
import
stubChildren
from
'
helpers/stub_children
'
;
import
stubChildren
from
'
helpers/stub_children
'
;
...
@@ -140,14 +141,13 @@ describe('EE MRWidget approvals footer', () => {
...
@@ -140,14 +141,13 @@ describe('EE MRWidget approvals footer', () => {
expect
(
icon
.
props
(
'
name
'
)).
toEqual
(
'
chevron-right
'
);
expect
(
icon
.
props
(
'
name
'
)).
toEqual
(
'
chevron-right
'
);
});
});
it
(
'
expands when clicked
'
,
()
=>
{
it
(
'
expands when clicked
'
,
async
()
=>
{
const
button
=
findToggle
();
const
button
=
findToggle
();
button
.
vm
.
$emit
(
'
click
'
);
button
.
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
input
).
toEqual
([[
true
]]);
expect
(
wrapper
.
emitted
().
input
).
toEqual
([[
true
]]);
});
});
});
});
});
...
@@ -184,18 +184,13 @@ describe('EE MRWidget approvals footer', () => {
...
@@ -184,18 +184,13 @@ describe('EE MRWidget approvals footer', () => {
expect
(
button
.
text
()).
toBe
(
'
View eligible approvers
'
);
expect
(
button
.
text
()).
toBe
(
'
View eligible approvers
'
);
});
});
it
(
'
expands when clicked
'
,
(
done
)
=>
{
it
(
'
expands when clicked
'
,
async
(
)
=>
{
expect
(
wrapper
.
props
(
'
value
'
)).
toBe
(
false
);
expect
(
wrapper
.
props
(
'
value
'
)).
toBe
(
false
);
button
.
vm
.
$emit
(
'
click
'
);
button
.
vm
.
$emit
(
'
click
'
);
wrapper
.
vm
await
nextTick
();
.
$nextTick
()
expect
(
wrapper
.
emitted
().
input
).
toEqual
([[
true
]]);
.
then
(()
=>
{
expect
(
wrapper
.
emitted
().
input
).
toEqual
([[
true
]]);
})
.
then
(
done
)
.
catch
(
done
.
fail
);
});
});
});
});
});
});
...
...
ee/spec/frontend/vue_mr_widget/components/approvals/approvals_spec.js
View file @
6979e878
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
Approvals
from
'
ee/vue_merge_request_widget/components/approvals/approvals.vue
'
;
import
Approvals
from
'
ee/vue_merge_request_widget/components/approvals/approvals.vue
'
;
import
ApprovalsAuth
from
'
ee/vue_merge_request_widget/components/approvals/approvals_auth.vue
'
;
import
ApprovalsAuth
from
'
ee/vue_merge_request_widget/components/approvals/approvals_auth.vue
'
;
import
ApprovalsFooter
from
'
ee/vue_merge_request_widget/components/approvals/approvals_footer.vue
'
;
import
ApprovalsFooter
from
'
ee/vue_merge_request_widget/components/approvals/approvals_footer.vue
'
;
...
@@ -107,12 +108,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -107,12 +108,11 @@ describe('EE MRWidget approvals', () => {
createComponent
();
createComponent
();
});
});
it
(
'
shows loading message
'
,
()
=>
{
it
(
'
shows loading message
'
,
async
()
=>
{
wrapper
.
findComponent
(
ApprovalsFoss
).
setData
({
fetchingApprovals
:
true
});
wrapper
.
findComponent
(
ApprovalsFoss
).
setData
({
fetchingApprovals
:
true
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
text
()).
toContain
(
FETCH_LOADING
);
expect
(
wrapper
.
text
()).
toContain
(
FETCH_LOADING
);
});
});
});
it
(
'
fetches approvals
'
,
()
=>
{
it
(
'
fetches approvals
'
,
()
=>
{
...
@@ -121,11 +121,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -121,11 +121,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when fetch approvals success
'
,
()
=>
{
describe
(
'
when fetch approvals success
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockResolvedValue
();
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockResolvedValue
();
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
hides loading message
'
,
()
=>
{
it
(
'
hides loading message
'
,
()
=>
{
...
@@ -135,11 +135,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -135,11 +135,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when fetch approvals error
'
,
()
=>
{
describe
(
'
when fetch approvals error
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockRejectedValue
();
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockRejectedValue
();
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
still shows loading message
'
,
()
=>
{
it
(
'
still shows loading message
'
,
()
=>
{
...
@@ -157,14 +157,14 @@ describe('EE MRWidget approvals', () => {
...
@@ -157,14 +157,14 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when mr is closed
'
,
()
=>
{
describe
(
'
when mr is closed
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
isOpen
=
false
;
mr
.
isOpen
=
false
;
mr
.
approvals
.
user_has_approved
=
false
;
mr
.
approvals
.
user_has_approved
=
false
;
mr
.
approvals
.
user_can_approve
=
true
;
mr
.
approvals
.
user_can_approve
=
true
;
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
action is not rendered
'
,
()
=>
{
it
(
'
action is not rendered
'
,
()
=>
{
...
@@ -173,13 +173,13 @@ describe('EE MRWidget approvals', () => {
...
@@ -173,13 +173,13 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when user cannot approve
'
,
()
=>
{
describe
(
'
when user cannot approve
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
user_has_approved
=
false
;
mr
.
approvals
.
user_has_approved
=
false
;
mr
.
approvals
.
user_can_approve
=
false
;
mr
.
approvals
.
user_can_approve
=
false
;
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
action is not rendered
'
,
()
=>
{
it
(
'
action is not rendered
'
,
()
=>
{
...
@@ -194,10 +194,10 @@ describe('EE MRWidget approvals', () => {
...
@@ -194,10 +194,10 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and MR is unapproved
'
,
()
=>
{
describe
(
'
and MR is unapproved
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
approve action is rendered
'
,
()
=>
{
it
(
'
approve action is rendered
'
,
()
=>
{
...
@@ -215,11 +215,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -215,11 +215,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
with no approvers
'
,
()
=>
{
describe
(
'
with no approvers
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
approved_by
=
[];
mr
.
approvals
.
approved_by
=
[];
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
approve action (with inverted style) is rendered
'
,
()
=>
{
it
(
'
approve action (with inverted style) is rendered
'
,
()
=>
{
...
@@ -232,11 +232,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -232,11 +232,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
with approvers
'
,
()
=>
{
describe
(
'
with approvers
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
approved_by
=
[{
user
:
{
id
:
7
}
}];
mr
.
approvals
.
approved_by
=
[{
user
:
{
id
:
7
}
}];
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
approve additionally action is rendered
'
,
()
=>
{
it
(
'
approve additionally action is rendered
'
,
()
=>
{
...
@@ -250,13 +250,13 @@ describe('EE MRWidget approvals', () => {
...
@@ -250,13 +250,13 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when approve action is clicked
'
,
()
=>
{
describe
(
'
when approve action is clicked
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
shows loading icon
'
,
()
=>
{
it
(
'
shows loading icon
'
,
async
()
=>
{
jest
.
spyOn
(
service
,
'
approveMergeRequest
'
).
mockReturnValue
(
new
Promise
(()
=>
{}));
jest
.
spyOn
(
service
,
'
approveMergeRequest
'
).
mockReturnValue
(
new
Promise
(()
=>
{}));
const
action
=
findAction
();
const
action
=
findAction
();
...
@@ -264,16 +264,15 @@ describe('EE MRWidget approvals', () => {
...
@@ -264,16 +264,15 @@ describe('EE MRWidget approvals', () => {
action
.
vm
.
$emit
(
'
click
'
);
action
.
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
action
.
props
(
'
loading
'
)).
toBe
(
true
);
expect
(
action
.
props
(
'
loading
'
)).
toBe
(
true
);
});
});
});
describe
(
'
and after loading
'
,
()
=>
{
describe
(
'
and after loading
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
findAction
().
vm
.
$emit
(
'
click
'
);
findAction
().
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
calls service approve
'
,
()
=>
{
it
(
'
calls service approve
'
,
()
=>
{
...
@@ -294,11 +293,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -294,11 +293,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and error
'
,
()
=>
{
describe
(
'
and error
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
approveMergeRequest
'
).
mockRejectedValue
();
jest
.
spyOn
(
service
,
'
approveMergeRequest
'
).
mockRejectedValue
();
findAction
().
vm
.
$emit
(
'
click
'
);
findAction
().
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
flashes error message
'
,
()
=>
{
it
(
'
flashes error message
'
,
()
=>
{
...
@@ -308,50 +307,48 @@ describe('EE MRWidget approvals', () => {
...
@@ -308,50 +307,48 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when project requires password to approve
'
,
()
=>
{
describe
(
'
when project requires password to approve
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
require_password_to_approve
=
true
;
mr
.
approvals
.
require_password_to_approve
=
true
;
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
describe
(
'
when approve is clicked
'
,
()
=>
{
describe
(
'
when approve is clicked
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
findAction
().
vm
.
$emit
(
'
click
'
);
findAction
().
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
describe
(
'
when emits approve
'
,
()
=>
{
describe
(
'
when emits approve
'
,
()
=>
{
const
findApprovalsAuth
=
()
=>
wrapper
.
findComponent
(
ApprovalsAuth
);
const
findApprovalsAuth
=
()
=>
wrapper
.
findComponent
(
ApprovalsAuth
);
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
approveMergeRequestWithAuth
'
).
mockRejectedValue
();
jest
.
spyOn
(
service
,
'
approveMergeRequestWithAuth
'
).
mockRejectedValue
();
jest
.
spyOn
(
service
,
'
approveMergeRequest
'
).
mockReturnValue
(
new
Promise
(()
=>
{}));
jest
.
spyOn
(
service
,
'
approveMergeRequest
'
).
mockReturnValue
(
new
Promise
(()
=>
{}));
findApprovalsAuth
().
vm
.
$emit
(
'
approve
'
,
TEST_PASSWORD
);
findApprovalsAuth
().
vm
.
$emit
(
'
approve
'
,
TEST_PASSWORD
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
calls service when emits approve
'
,
()
=>
{
it
(
'
calls service when emits approve
'
,
()
=>
{
expect
(
service
.
approveMergeRequestWithAuth
).
toHaveBeenCalledWith
(
TEST_PASSWORD
);
expect
(
service
.
approveMergeRequestWithAuth
).
toHaveBeenCalledWith
(
TEST_PASSWORD
);
});
});
it
(
'
sets isApproving
'
,
()
=>
{
it
(
'
sets isApproving
'
,
async
()
=>
{
wrapper
.
findComponent
(
ApprovalsFoss
).
setData
({
isApproving
:
true
});
wrapper
.
findComponent
(
ApprovalsFoss
).
setData
({
isApproving
:
true
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
findApprovalsAuth
().
props
(
'
isApproving
'
)).
toBe
(
true
);
expect
(
findApprovalsAuth
().
props
(
'
isApproving
'
)).
toBe
(
true
);
});
});
});
it
(
'
sets hasError when auth fails
'
,
()
=>
{
it
(
'
sets hasError when auth fails
'
,
async
()
=>
{
wrapper
.
findComponent
(
ApprovalsFoss
).
setData
({
hasApprovalAuthError
:
true
});
wrapper
.
findComponent
(
ApprovalsFoss
).
setData
({
hasApprovalAuthError
:
true
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
findApprovalsAuth
().
props
(
'
hasError
'
)).
toBe
(
true
);
expect
(
findApprovalsAuth
().
props
(
'
hasError
'
)).
toBe
(
true
);
});
});
});
it
(
'
shows flash if general error
'
,
()
=>
{
it
(
'
shows flash if general error
'
,
()
=>
{
...
@@ -363,13 +360,13 @@ describe('EE MRWidget approvals', () => {
...
@@ -363,13 +360,13 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
when user has approved
'
,
()
=>
{
describe
(
'
when user has approved
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
user_has_approved
=
true
;
mr
.
approvals
.
user_has_approved
=
true
;
mr
.
approvals
.
user_can_approve
=
false
;
mr
.
approvals
.
user_can_approve
=
false
;
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
revoke action is rendered
'
,
()
=>
{
it
(
'
revoke action is rendered
'
,
()
=>
{
...
@@ -382,10 +379,10 @@ describe('EE MRWidget approvals', () => {
...
@@ -382,10 +379,10 @@ describe('EE MRWidget approvals', () => {
describe
(
'
when revoke action is clicked
'
,
()
=>
{
describe
(
'
when revoke action is clicked
'
,
()
=>
{
describe
(
'
and successful
'
,
()
=>
{
describe
(
'
and successful
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
findAction
().
vm
.
$emit
(
'
click
'
);
findAction
().
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
calls service unapprove
'
,
()
=>
{
it
(
'
calls service unapprove
'
,
()
=>
{
...
@@ -406,11 +403,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -406,11 +403,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and error
'
,
()
=>
{
describe
(
'
and error
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
unapproveMergeRequest
'
).
mockRejectedValue
();
jest
.
spyOn
(
service
,
'
unapproveMergeRequest
'
).
mockRejectedValue
();
findAction
().
vm
.
$emit
(
'
click
'
);
findAction
().
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
flashes error message
'
,
()
=>
{
it
(
'
flashes error message
'
,
()
=>
{
...
@@ -431,12 +428,12 @@ describe('EE MRWidget approvals', () => {
...
@@ -431,12 +428,12 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and can approve
'
,
()
=>
{
describe
(
'
and can approve
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
user_can_approve
=
true
;
mr
.
approvals
.
user_can_approve
=
true
;
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
is shown
'
,
()
=>
{
it
(
'
is shown
'
,
()
=>
{
...
@@ -449,12 +446,12 @@ describe('EE MRWidget approvals', () => {
...
@@ -449,12 +446,12 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and cannot approve
'
,
()
=>
{
describe
(
'
and cannot approve
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
mr
.
approvals
.
user_can_approve
=
false
;
mr
.
approvals
.
user_can_approve
=
false
;
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
is shown
'
,
()
=>
{
it
(
'
is shown
'
,
()
=>
{
...
@@ -469,11 +466,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -469,11 +466,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
approvals summary
'
,
()
=>
{
describe
(
'
approvals summary
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockResolvedValue
(
testApprovals
());
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockResolvedValue
(
testApprovals
());
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
is rendered with props
'
,
()
=>
{
it
(
'
is rendered with props
'
,
()
=>
{
...
@@ -493,11 +490,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -493,11 +490,11 @@ describe('EE MRWidget approvals', () => {
describe
(
'
footer
'
,
()
=>
{
describe
(
'
footer
'
,
()
=>
{
let
footer
;
let
footer
;
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockResolvedValue
(
testApprovals
());
jest
.
spyOn
(
service
,
'
fetchApprovals
'
).
mockResolvedValue
(
testApprovals
());
createComponent
();
createComponent
();
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
beforeEach
(()
=>
{
beforeEach
(()
=>
{
...
@@ -516,11 +513,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -516,11 +513,11 @@ describe('EE MRWidget approvals', () => {
describe
(
'
when opened
'
,
()
=>
{
describe
(
'
when opened
'
,
()
=>
{
describe
(
'
and loading
'
,
()
=>
{
describe
(
'
and loading
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
jest
.
spyOn
(
service
,
'
fetchApprovalSettings
'
).
mockReturnValue
(
new
Promise
(()
=>
{}));
jest
.
spyOn
(
service
,
'
fetchApprovalSettings
'
).
mockReturnValue
(
new
Promise
(()
=>
{}));
footer
.
vm
.
$emit
(
'
input
'
,
true
);
footer
.
vm
.
$emit
(
'
input
'
,
true
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
calls service fetch approval rules
'
,
()
=>
{
it
(
'
calls service fetch approval rules
'
,
()
=>
{
...
@@ -534,10 +531,10 @@ describe('EE MRWidget approvals', () => {
...
@@ -534,10 +531,10 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and finished loading
'
,
()
=>
{
describe
(
'
and finished loading
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
footer
.
vm
.
$emit
(
'
input
'
,
true
);
footer
.
vm
.
$emit
(
'
input
'
,
true
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
sets approval rules
'
,
()
=>
{
it
(
'
sets approval rules
'
,
()
=>
{
...
@@ -549,11 +546,11 @@ describe('EE MRWidget approvals', () => {
...
@@ -549,11 +546,11 @@ describe('EE MRWidget approvals', () => {
});
});
describe
(
'
and closed
'
,
()
=>
{
describe
(
'
and closed
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
service
.
fetchApprovalSettings
.
mockClear
();
service
.
fetchApprovalSettings
.
mockClear
();
footer
.
vm
.
$emit
(
'
input
'
,
false
);
footer
.
vm
.
$emit
(
'
input
'
,
false
);
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
does not call service fetch approval rules
'
,
()
=>
{
it
(
'
does not call service fetch approval rules
'
,
()
=>
{
...
...
ee/spec/frontend/vue_mr_widget/components/merge_immediately_confirmation_dialog_spec.js
View file @
6979e878
import
{
GlSprintf
,
GlLink
}
from
'
@gitlab/ui
'
;
import
{
GlSprintf
,
GlLink
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
MergeImmediatelyConfirmationDialog
from
'
ee/vue_merge_request_widget/components/merge_immediately_confirmation_dialog.vue
'
;
import
MergeImmediatelyConfirmationDialog
from
'
ee/vue_merge_request_widget/components/merge_immediately_confirmation_dialog.vue
'
;
import
{
trimText
}
from
'
helpers/text_helper
'
;
import
{
trimText
}
from
'
helpers/text_helper
'
;
...
@@ -7,7 +8,7 @@ describe('MergeImmediatelyConfirmationDialog', () => {
...
@@ -7,7 +8,7 @@ describe('MergeImmediatelyConfirmationDialog', () => {
const
docsUrl
=
'
path/to/merge/immediately/docs
'
;
const
docsUrl
=
'
path/to/merge/immediately/docs
'
;
let
wrapper
;
let
wrapper
;
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
wrapper
=
shallowMount
(
MergeImmediatelyConfirmationDialog
,
{
wrapper
=
shallowMount
(
MergeImmediatelyConfirmationDialog
,
{
propsData
:
{
docsUrl
},
propsData
:
{
docsUrl
},
stubs
:
{
stubs
:
{
...
@@ -15,7 +16,7 @@ describe('MergeImmediatelyConfirmationDialog', () => {
...
@@ -15,7 +16,7 @@ describe('MergeImmediatelyConfirmationDialog', () => {
},
},
});
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
should render informational text explaining why merging immediately can be dangerous
'
,
()
=>
{
it
(
'
should render informational text explaining why merging immediately can be dangerous
'
,
()
=>
{
...
...
ee/spec/frontend/vue_mr_widget/components/states/mr_widget_enable_feature_prompt_spec.js
View file @
6979e878
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
MrWidgetEnableFeaturePrompt
from
'
ee/vue_merge_request_widget/components/states/mr_widget_enable_feature_prompt.vue
'
;
import
MrWidgetEnableFeaturePrompt
from
'
ee/vue_merge_request_widget/components/states/mr_widget_enable_feature_prompt.vue
'
;
import
{
stubExperiments
}
from
'
helpers/experimentation_helper
'
;
import
{
stubExperiments
}
from
'
helpers/experimentation_helper
'
;
import
CiIcon
from
'
~/vue_shared/components/ci_icon.vue
'
;
import
CiIcon
from
'
~/vue_shared/components/ci_icon.vue
'
;
...
@@ -56,7 +57,7 @@ describe('MrWidgetEnableFeaturePrompt', () => {
...
@@ -56,7 +57,7 @@ describe('MrWidgetEnableFeaturePrompt', () => {
const
button
=
findDismissButton
();
const
button
=
findDismissButton
();
button
.
vm
.
$emit
(
'
click
'
);
button
.
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
localStorage
.
getItem
(
LOCAL_STORAGE_KEY
)).
toBe
(
'
true
'
);
expect
(
localStorage
.
getItem
(
LOCAL_STORAGE_KEY
)).
toBe
(
'
true
'
);
expect
(
wrapper
.
text
()).
toBe
(
''
);
expect
(
wrapper
.
text
()).
toBe
(
''
);
...
...
ee/spec/frontend/vue_mr_widget/components/states/mr_widget_ready_to_merge_spec.js
View file @
6979e878
import
{
GlLink
,
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
GlLink
,
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
MergeImmediatelyConfirmationDialog
from
'
ee/vue_merge_request_widget/components/merge_immediately_confirmation_dialog.vue
'
;
import
MergeImmediatelyConfirmationDialog
from
'
ee/vue_merge_request_widget/components/merge_immediately_confirmation_dialog.vue
'
;
import
MergeTrainFailedPipelineConfirmationDialog
from
'
ee/vue_merge_request_widget/components/merge_train_failed_pipeline_confirmation_dialog.vue
'
;
import
MergeTrainFailedPipelineConfirmationDialog
from
'
ee/vue_merge_request_widget/components/merge_train_failed_pipeline_confirmation_dialog.vue
'
;
import
MergeTrainHelperIcon
from
'
ee/vue_merge_request_widget/components/merge_train_helper_icon.vue
'
;
import
MergeTrainHelperIcon
from
'
ee/vue_merge_request_widget/components/merge_train_helper_icon.vue
'
;
...
@@ -297,41 +298,35 @@ describe('ReadyToMerge', () => {
...
@@ -297,41 +298,35 @@ describe('ReadyToMerge', () => {
describe
(
'
merge immediately warning dialog
'
,
()
=>
{
describe
(
'
merge immediately warning dialog
'
,
()
=>
{
let
dialog
;
let
dialog
;
const
clickMergeImmediately
=
()
=>
{
const
clickMergeImmediately
=
async
()
=>
{
dialog
=
wrapper
.
findComponent
(
MergeImmediatelyConfirmationDialog
);
dialog
=
wrapper
.
findComponent
(
MergeImmediatelyConfirmationDialog
);
expect
(
dialog
.
exists
()).
toBe
(
true
);
expect
(
dialog
.
exists
()).
toBe
(
true
);
dialog
.
vm
.
show
=
jest
.
fn
();
dialog
.
vm
.
show
=
jest
.
fn
();
vm
.
handleMergeButtonClick
=
jest
.
fn
();
vm
.
handleMergeButtonClick
=
jest
.
fn
();
findMergeButtonDropdown
().
trigger
(
'
click
'
);
findMergeButtonDropdown
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
findMergeImmediatelyButton
().
trigger
(
'
click
'
);
findMergeImmediatelyButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
();
await
nextTick
();
});
};
};
it
(
'
should show a warning dialog asking for confirmation if the user is trying to skip the merge train
'
,
()
=>
{
it
(
'
should show a warning dialog asking for confirmation if the user is trying to skip the merge train
'
,
async
()
=>
{
factory
({
preferredAutoMergeStrategy
:
MT_MERGE_STRATEGY
},
false
);
factory
({
preferredAutoMergeStrategy
:
MT_MERGE_STRATEGY
},
false
);
return
clickMergeImmediately
().
then
(()
=>
{
await
clickMergeImmediately
();
expect
(
dialog
.
vm
.
show
).
toHaveBeenCalled
();
expect
(
dialog
.
vm
.
show
).
toHaveBeenCalled
();
expect
(
vm
.
handleMergeButtonClick
).
not
.
toHaveBeenCalled
();
expect
(
vm
.
handleMergeButtonClick
).
not
.
toHaveBeenCalled
();
});
});
});
it
(
'
should perform the merge when the user confirms their intent to merge immediately
'
,
()
=>
{
it
(
'
should perform the merge when the user confirms their intent to merge immediately
'
,
async
()
=>
{
factory
({
preferredAutoMergeStrategy
:
MT_MERGE_STRATEGY
},
false
);
factory
({
preferredAutoMergeStrategy
:
MT_MERGE_STRATEGY
},
false
);
return
clickMergeImmediately
()
await
clickMergeImmediately
();
.
then
(()
=>
{
dialog
.
vm
.
$emit
(
'
mergeImmediately
'
);
dialog
.
vm
.
$emit
(
'
mergeImmediately
'
);
await
nextTick
();
return
wrapper
.
vm
.
$nextTick
();
// false (no auto merge), true (merge immediately), true (confirmation clicked)
})
expect
(
vm
.
handleMergeButtonClick
).
toHaveBeenCalledWith
(
false
,
true
,
true
);
.
then
(()
=>
{
// false (no auto merge), true (merge immediately), true (confirmation clicked)
expect
(
vm
.
handleMergeButtonClick
).
toHaveBeenCalledWith
(
false
,
true
,
true
);
});
});
});
it
(
'
should not ask for confirmation in non-merge train scenarios
'
,
()
=>
{
it
(
'
should not ask for confirmation in non-merge train scenarios
'
,
async
()
=>
{
factory
(
factory
(
{
{
isPipelineActive
:
true
,
isPipelineActive
:
true
,
...
@@ -339,10 +334,9 @@ describe('ReadyToMerge', () => {
...
@@ -339,10 +334,9 @@ describe('ReadyToMerge', () => {
},
},
false
,
false
,
);
);
return
clickMergeImmediately
().
then
(()
=>
{
await
clickMergeImmediately
();
expect
(
dialog
.
vm
.
show
).
not
.
toHaveBeenCalled
();
expect
(
dialog
.
vm
.
show
).
not
.
toHaveBeenCalled
();
expect
(
vm
.
handleMergeButtonClick
).
toHaveBeenCalled
();
expect
(
vm
.
handleMergeButtonClick
).
toHaveBeenCalled
();
});
});
});
});
});
...
...
ee/spec/frontend/vue_mr_widget/ee_mr_widget_options_spec.js
View file @
6979e878
...
@@ -393,30 +393,28 @@ describe('ee merge request widget options', () => {
...
@@ -393,30 +393,28 @@ describe('ee merge request widget options', () => {
describe
(
'
text connector
'
,
()
=>
{
describe
(
'
text connector
'
,
()
=>
{
it
(
'
should only render information about fixed issues
'
,
(
done
)
=>
{
it
(
'
should only render information about fixed issues
'
,
(
done
)
=>
{
setImmediate
(()
=>
{
setImmediate
(
async
()
=>
{
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
degraded
=
[];
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
degraded
=
[];
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
same
=
[];
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
same
=
[];
nextTick
(()
=>
{
await
nextTick
();
expect
(
expect
(
trimText
(
wrapper
.
find
(
'
.js-browser-performance-widget .js-code-text
'
).
text
()),
trimText
(
wrapper
.
find
(
'
.js-browser-performance-widget .js-code-text
'
).
text
()),
).
toEqual
(
'
Browser performance test metrics: 1 improved
'
);
).
toEqual
(
'
Browser performance test metrics: 1 improved
'
);
done
();
done
();
});
});
});
});
});
it
(
'
should only render information about added issues
'
,
(
done
)
=>
{
it
(
'
should only render information about added issues
'
,
(
done
)
=>
{
setImmediate
(()
=>
{
setImmediate
(
async
()
=>
{
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
improved
=
[];
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
improved
=
[];
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
same
=
[];
wrapper
.
vm
.
mr
.
browserPerformanceMetrics
.
same
=
[];
nextTick
(()
=>
{
await
nextTick
();
expect
(
expect
(
trimText
(
wrapper
.
find
(
'
.js-browser-performance-widget .js-code-text
'
).
text
()),
trimText
(
wrapper
.
find
(
'
.js-browser-performance-widget .js-code-text
'
).
text
()),
).
toEqual
(
'
Browser performance test metrics: 2 degraded
'
);
).
toEqual
(
'
Browser performance test metrics: 2 degraded
'
);
done
();
done
();
});
});
});
});
});
});
});
...
@@ -537,28 +535,24 @@ describe('ee merge request widget options', () => {
...
@@ -537,28 +535,24 @@ describe('ee merge request widget options', () => {
});
});
describe
(
'
text connector
'
,
()
=>
{
describe
(
'
text connector
'
,
()
=>
{
it
(
'
should only render information about fixed issues
'
,
(
done
)
=>
{
it
(
'
should only render information about fixed issues
'
,
async
(
)
=>
{
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
degraded
=
[];
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
degraded
=
[];
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
same
=
[];
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
same
=
[];
nextTick
(()
=>
{
await
nextTick
();
expect
(
expect
(
trimText
(
wrapper
.
find
(
'
.js-load-performance-widget .js-code-text
'
).
text
())).
toBe
(
trimText
(
wrapper
.
find
(
'
.js-load-performance-widget .js-code-text
'
).
text
()),
'
Load performance test metrics: 2 improved
'
,
).
toBe
(
'
Load performance test metrics: 2 improved
'
);
);
done
();
});
});
});
it
(
'
should only render information about added issues
'
,
(
done
)
=>
{
it
(
'
should only render information about added issues
'
,
async
(
)
=>
{
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
improved
=
[];
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
improved
=
[];
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
same
=
[];
wrapper
.
vm
.
mr
.
loadPerformanceMetrics
.
same
=
[];
nextTick
(()
=>
{
await
nextTick
();
expect
(
expect
(
trimText
(
wrapper
.
find
(
'
.js-load-performance-widget .js-code-text
'
).
text
())).
toBe
(
trimText
(
wrapper
.
find
(
'
.js-load-performance-widget .js-code-text
'
).
text
()),
'
Load performance test metrics: 1 degraded
'
,
).
toBe
(
'
Load performance test metrics: 1 degraded
'
);
);
done
();
});
});
});
});
});
});
});
...
@@ -1091,34 +1085,28 @@ describe('ee merge request widget options', () => {
...
@@ -1091,34 +1085,28 @@ describe('ee merge request widget options', () => {
});
});
});
});
it
(
'
renders when user cannot remove branch and branch should be removed
'
,
(
done
)
=>
{
it
(
'
renders when user cannot remove branch and branch should be removed
'
,
async
(
)
=>
{
wrapper
.
vm
.
mr
.
canRemoveSourceBranch
=
false
;
wrapper
.
vm
.
mr
.
canRemoveSourceBranch
=
false
;
wrapper
.
vm
.
mr
.
shouldRemoveSourceBranch
=
true
;
wrapper
.
vm
.
mr
.
shouldRemoveSourceBranch
=
true
;
wrapper
.
vm
.
mr
.
state
=
'
readyToMerge
'
;
wrapper
.
vm
.
mr
.
state
=
'
readyToMerge
'
;
nextTick
(()
=>
{
await
nextTick
();
const
tooltip
=
wrapper
.
find
(
'
[data-testid="question-o-icon"]
'
);
const
tooltip
=
wrapper
.
find
(
'
[data-testid="question-o-icon"]
'
);
expect
(
wrapper
.
text
()).
toContain
(
'
Deletes the source branch
'
);
expect
(
tooltip
.
attributes
(
'
title
'
)).
toBe
(
'
A user with write access to the source branch selected this option
'
,
);
done
();
expect
(
wrapper
.
text
()).
toContain
(
'
Deletes the source branch
'
);
});
expect
(
tooltip
.
attributes
(
'
title
'
)).
toBe
(
'
A user with write access to the source branch selected this option
'
,
);
});
});
it
(
'
does not render in merged state
'
,
(
done
)
=>
{
it
(
'
does not render in merged state
'
,
async
(
)
=>
{
wrapper
.
vm
.
mr
.
canRemoveSourceBranch
=
false
;
wrapper
.
vm
.
mr
.
canRemoveSourceBranch
=
false
;
wrapper
.
vm
.
mr
.
shouldRemoveSourceBranch
=
true
;
wrapper
.
vm
.
mr
.
shouldRemoveSourceBranch
=
true
;
wrapper
.
vm
.
mr
.
state
=
'
merged
'
;
wrapper
.
vm
.
mr
.
state
=
'
merged
'
;
nextTick
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
text
()).
toContain
(
'
The source branch has been deleted
'
);
expect
(
wrapper
.
text
()).
toContain
(
'
The source branch has been deleted
'
);
expect
(
wrapper
.
text
()).
not
.
toContain
(
'
Removes source branch
'
);
expect
(
wrapper
.
text
()).
not
.
toContain
(
'
Removes source branch
'
);
done
();
});
});
});
});
});
...
@@ -1137,7 +1125,7 @@ describe('ee merge request widget options', () => {
...
@@ -1137,7 +1125,7 @@ describe('ee merge request widget options', () => {
status
:
SUCCESS
,
status
:
SUCCESS
,
};
};
beforeEach
(
(
done
)
=>
{
beforeEach
(
async
(
)
=>
{
createComponent
({
createComponent
({
propsData
:
{
propsData
:
{
mrData
:
{
mrData
:
{
...
@@ -1156,7 +1144,7 @@ describe('ee merge request widget options', () => {
...
@@ -1156,7 +1144,7 @@ describe('ee merge request widget options', () => {
},
},
);
);
nextTick
(
done
);
await
nextTick
(
);
});
});
it
(
'
renders multiple deployments
'
,
()
=>
{
it
(
'
renders multiple deployments
'
,
()
=>
{
...
...
ee/spec/frontend/vue_shared/components/accordion/accordion_item_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
uniqueId
}
from
'
lodash
'
;
import
{
uniqueId
}
from
'
lodash
'
;
import
{
AccordionItem
}
from
'
ee/vue_shared/components/accordion
'
;
import
{
AccordionItem
}
from
'
ee/vue_shared/components/accordion
'
;
import
accordionEventBus
from
'
ee/vue_shared/components/accordion/accordion_event_bus
'
;
import
accordionEventBus
from
'
ee/vue_shared/components/accordion/accordion_event_bus
'
;
...
@@ -89,17 +90,16 @@ describe('AccordionItem component', () => {
...
@@ -89,17 +90,16 @@ describe('AccordionItem component', () => {
it
.
each
([
true
,
false
])(
it
.
each
([
true
,
false
])(
'
passes the "isExpanded" and "isDisabled" state to the title slot
'
,
'
passes the "isExpanded" and "isDisabled" state to the title slot
'
,
(
state
)
=>
{
async
(
state
)
=>
{
const
titleSlot
=
jest
.
fn
();
const
titleSlot
=
jest
.
fn
();
factory
({
propsData
:
{
disabled
:
state
},
titleSlot
});
factory
({
propsData
:
{
disabled
:
state
},
titleSlot
});
wrapper
.
vm
.
isExpanded
=
state
;
wrapper
.
vm
.
isExpanded
=
state
;
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
titleSlot
).
toHaveBeenCalledWith
({
expect
(
titleSlot
).
toHaveBeenCalledWith
({
isExpanded
:
state
,
isExpanded
:
state
,
isDisabled
:
state
,
isDisabled
:
state
,
});
});
});
},
},
);
);
...
@@ -112,14 +112,13 @@ describe('AccordionItem component', () => {
...
@@ -112,14 +112,13 @@ describe('AccordionItem component', () => {
expect
(
contentContainer
().
isVisible
()).
toBe
(
false
);
expect
(
contentContainer
().
isVisible
()).
toBe
(
false
);
});
});
it
(
'
expands when the trigger-element gets clicked
'
,
()
=>
{
it
(
'
expands when the trigger-element gets clicked
'
,
async
()
=>
{
expect
(
contentContainer
().
isVisible
()).
toBe
(
false
);
expect
(
contentContainer
().
isVisible
()).
toBe
(
false
);
expansionTrigger
().
trigger
(
'
click
'
);
expansionTrigger
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
contentContainer
().
isVisible
()).
toBe
(
true
);
expect
(
contentContainer
().
isVisible
()).
toBe
(
true
);
});
});
});
it
(
'
emits a namespaced "closeOtherAccordionItems" event, containing the trigger item as a payload
'
,
()
=>
{
it
(
'
emits a namespaced "closeOtherAccordionItems" event, containing the trigger item as a payload
'
,
()
=>
{
...
@@ -178,16 +177,15 @@ describe('AccordionItem component', () => {
...
@@ -178,16 +177,15 @@ describe('AccordionItem component', () => {
expect
(
contentContainer
().
attributes
(
'
id
'
)).
toBe
(
mockUniqueId
);
expect
(
contentContainer
().
attributes
(
'
id
'
)).
toBe
(
mockUniqueId
);
});
});
it
(
'
has a trigger element that has an "aria-expanded" attribute set, to show if it is expanded or collapsed
'
,
()
=>
{
it
(
'
has a trigger element that has an "aria-expanded" attribute set, to show if it is expanded or collapsed
'
,
async
()
=>
{
expect
(
expansionTrigger
().
attributes
(
'
aria-expanded
'
)).
toBeFalsy
();
expect
(
expansionTrigger
().
attributes
(
'
aria-expanded
'
)).
toBeFalsy
();
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
// eslint-disable-next-line no-restricted-syntax
// eslint-disable-next-line no-restricted-syntax
wrapper
.
setData
({
isExpanded
:
true
});
wrapper
.
setData
({
isExpanded
:
true
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
expansionTrigger
().
attributes
(
'
aria-expanded
'
)).
toBe
(
'
true
'
);
expect
(
expansionTrigger
().
attributes
(
'
aria-expanded
'
)).
toBe
(
'
true
'
);
});
});
});
it
(
'
has a trigger element that has a "aria-controls" attribute, which points to the content element
'
,
()
=>
{
it
(
'
has a trigger element that has a "aria-controls" attribute, which points to the content element
'
,
()
=>
{
...
...
ee/spec/frontend/vue_shared/components/filtered_search_bar/tokens/epic_token_spec.js
View file @
6979e878
import
{
GlFilteredSearchTokenSegment
}
from
'
@gitlab/ui
'
;
import
{
GlFilteredSearchTokenSegment
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
import
createMockApollo
from
'
helpers/mock_apollo_helper
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
...
@@ -79,7 +79,7 @@ describe('EpicToken', () => {
...
@@ -79,7 +79,7 @@ describe('EpicToken', () => {
},
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
});
});
...
@@ -138,7 +138,7 @@ describe('EpicToken', () => {
...
@@ -138,7 +138,7 @@ describe('EpicToken', () => {
data
:
{
epics
:
mockEpics
},
data
:
{
epics
:
mockEpics
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
renders BaseToken component
'
,
()
=>
{
it
(
'
renders BaseToken component
'
,
()
=>
{
...
@@ -161,7 +161,7 @@ describe('EpicToken', () => {
...
@@ -161,7 +161,7 @@ describe('EpicToken', () => {
value
:
{
data
:
value
},
value
:
{
data
:
value
},
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
getTokenValueEl
().
text
()).
toBe
(
tokenValueString
);
expect
(
getTokenValueEl
().
text
()).
toBe
(
tokenValueString
);
});
});
...
...
ee/spec/frontend/vue_shared/components/filtered_search_bar/tokens/iteration_token_spec.js
View file @
6979e878
...
@@ -4,6 +4,7 @@ import {
...
@@ -4,6 +4,7 @@ import {
GlFilteredSearchSuggestion
,
GlFilteredSearchSuggestion
,
}
from
'
@gitlab/ui
'
;
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
createFlash
from
'
~/flash
'
;
import
createFlash
from
'
~/flash
'
;
import
IterationToken
from
'
ee/vue_shared/components/filtered_search_bar/tokens/iteration_token.vue
'
;
import
IterationToken
from
'
ee/vue_shared/components/filtered_search_bar/tokens/iteration_token.vue
'
;
...
@@ -70,7 +71,7 @@ describe('IterationToken', () => {
...
@@ -70,7 +71,7 @@ describe('IterationToken', () => {
it
(
'
renders iteration value
'
,
async
()
=>
{
it
(
'
renders iteration value
'
,
async
()
=>
{
wrapper
=
createComponent
({
value
:
{
data
:
id
}
});
wrapper
=
createComponent
({
value
:
{
data
:
id
}
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
tokenSegments
=
wrapper
.
findAllComponents
(
GlFilteredSearchTokenSegment
);
const
tokenSegments
=
wrapper
.
findAllComponents
(
GlFilteredSearchTokenSegment
);
...
...
ee/spec/frontend/vue_shared/components/sidebar/epics_select/base_spec.js
View file @
6979e878
import
{
GlLoadingIcon
,
GlDropdown
,
GlDropdownItem
,
GlSearchBoxByType
}
from
'
@gitlab/ui
'
;
import
{
GlLoadingIcon
,
GlDropdown
,
GlDropdownItem
,
GlSearchBoxByType
}
from
'
@gitlab/ui
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mount
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
DropdownVariant
}
from
'
ee/vue_shared/components/sidebar/epics_select//constants
'
;
import
{
DropdownVariant
}
from
'
ee/vue_shared/components/sidebar/epics_select//constants
'
;
import
EpicsSelectBase
from
'
ee/vue_shared/components/sidebar/epics_select/base.vue
'
;
import
EpicsSelectBase
from
'
ee/vue_shared/components/sidebar/epics_select/base.vue
'
;
import
DropdownValue
from
'
ee/vue_shared/components/sidebar/epics_select/dropdown_value.vue
'
;
import
DropdownValue
from
'
ee/vue_shared/components/sidebar/epics_select/dropdown_value.vue
'
;
...
@@ -74,7 +75,7 @@ describe('EpicsSelect', () => {
...
@@ -74,7 +75,7 @@ describe('EpicsSelect', () => {
issueId
:
123
,
issueId
:
123
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
$store
.
state
.
issueId
).
toBe
(
123
);
expect
(
wrapper
.
vm
.
$store
.
state
.
issueId
).
toBe
(
123
);
});
});
});
});
...
@@ -85,7 +86,7 @@ describe('EpicsSelect', () => {
...
@@ -85,7 +86,7 @@ describe('EpicsSelect', () => {
initialEpic
:
mockEpic2
,
initialEpic
:
mockEpic2
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
$store
.
state
.
selectedEpic
).
toBe
(
mockEpic2
);
expect
(
wrapper
.
vm
.
$store
.
state
.
selectedEpic
).
toBe
(
mockEpic2
);
});
});
});
});
...
@@ -96,7 +97,7 @@ describe('EpicsSelect', () => {
...
@@ -96,7 +97,7 @@ describe('EpicsSelect', () => {
initialEpic
:
mockEpic2
,
initialEpic
:
mockEpic2
,
});
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
$store
.
state
.
selectedEpic
).
toBe
(
mockEpic2
);
expect
(
wrapper
.
vm
.
$store
.
state
.
selectedEpic
).
toBe
(
mockEpic2
);
});
});
});
});
...
@@ -109,14 +110,14 @@ describe('EpicsSelect', () => {
...
@@ -109,14 +110,14 @@ describe('EpicsSelect', () => {
it
(
'
should call action `fetchEpics` with `searchQuery` when value is set and `groupEpics` is empty
'
,
async
()
=>
{
it
(
'
should call action `fetchEpics` with `searchQuery` when value is set and `groupEpics` is empty
'
,
async
()
=>
{
wrapper
.
vm
.
$store
.
dispatch
(
'
setSearchQuery
'
,
'
foo
'
);
wrapper
.
vm
.
$store
.
dispatch
(
'
setSearchQuery
'
,
'
foo
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
fetchEpics
).
toHaveBeenCalledWith
(
'
foo
'
);
expect
(
wrapper
.
vm
.
fetchEpics
).
toHaveBeenCalledWith
(
'
foo
'
);
});
});
it
(
'
should call action `fetchEpics` without any params when value is empty
'
,
async
()
=>
{
it
(
'
should call action `fetchEpics` without any params when value is empty
'
,
async
()
=>
{
wrapper
.
vm
.
$store
.
dispatch
(
'
setSearchQuery
'
,
''
);
wrapper
.
vm
.
$store
.
dispatch
(
'
setSearchQuery
'
,
''
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
vm
.
fetchEpics
).
toHaveBeenCalledWith
();
expect
(
wrapper
.
vm
.
fetchEpics
).
toHaveBeenCalledWith
();
});
});
});
});
...
@@ -175,7 +176,7 @@ describe('EpicsSelect', () => {
...
@@ -175,7 +176,7 @@ describe('EpicsSelect', () => {
epicIssueId
:
0
,
epicIssueId
:
0
,
});
});
await
wrapperStandalone
.
vm
.
$
nextTick
();
await
nextTick
();
wrapperStandalone
.
vm
.
handleItemSelect
(
mockEpic2
);
wrapperStandalone
.
vm
.
handleItemSelect
(
mockEpic2
);
expect
(
wrapperStandalone
.
emitted
(
'
epicSelect
'
)).
toBeTruthy
();
expect
(
wrapperStandalone
.
emitted
(
'
epicSelect
'
)).
toBeTruthy
();
...
@@ -219,7 +220,7 @@ describe('EpicsSelect', () => {
...
@@ -219,7 +220,7 @@ describe('EpicsSelect', () => {
it
(
'
should render DropdownValue component when `showDropdown` is false
'
,
async
()
=>
{
it
(
'
should render DropdownValue component when `showDropdown` is false
'
,
async
()
=>
{
wrapper
.
vm
.
showDropdown
=
false
;
wrapper
.
vm
.
showDropdown
=
false
;
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findComponent
(
DropdownValue
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
DropdownValue
).
exists
()).
toBe
(
true
);
});
});
...
@@ -230,7 +231,7 @@ describe('EpicsSelect', () => {
...
@@ -230,7 +231,7 @@ describe('EpicsSelect', () => {
it
(
'
should render dropdown container element when props `canEdit` & `showDropdown` are true
'
,
async
()
=>
{
it
(
'
should render dropdown container element when props `canEdit` & `showDropdown` are true
'
,
async
()
=>
{
showDropdown
();
showDropdown
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
find
(
'
.epic-dropdown-container
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
.epic-dropdown-container
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
GlDropdown
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
GlDropdown
).
exists
()).
toBe
(
true
);
});
});
...
@@ -242,20 +243,20 @@ describe('EpicsSelect', () => {
...
@@ -242,20 +243,20 @@ describe('EpicsSelect', () => {
it
(
'
should render dropdown menu container element when props `canEdit` & `showDropdown` are true
'
,
async
()
=>
{
it
(
'
should render dropdown menu container element when props `canEdit` & `showDropdown` are true
'
,
async
()
=>
{
showDropdown
();
showDropdown
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
find
(
'
.dropdown-menu-epics
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
.dropdown-menu-epics
'
).
exists
()).
toBe
(
true
);
});
});
it
(
'
should render a dropdown header component when props `canEdit` & `showDropdown` are true
'
,
async
()
=>
{
it
(
'
should render a dropdown header component when props `canEdit` & `showDropdown` are true
'
,
async
()
=>
{
showDropdown
();
showDropdown
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findComponent
(
GlDropdown
).
props
(
'
headerText
'
)).
toBe
(
'
Assign Epic
'
);
expect
(
wrapper
.
findComponent
(
GlDropdown
).
props
(
'
headerText
'
)).
toBe
(
'
Assign Epic
'
);
});
});
it
(
'
should render a dropdown header component when variant is "standalone"
'
,
async
()
=>
{
it
(
'
should render a dropdown header component when variant is "standalone"
'
,
async
()
=>
{
showDropdown
(
wrapperStandalone
);
showDropdown
(
wrapperStandalone
);
await
wrapperStandalone
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findComponent
(
GlDropdown
).
props
(
'
headerText
'
)).
toBe
(
'
Assign Epic
'
);
expect
(
wrapper
.
findComponent
(
GlDropdown
).
props
(
'
headerText
'
)).
toBe
(
'
Assign Epic
'
);
});
});
...
@@ -263,7 +264,7 @@ describe('EpicsSelect', () => {
...
@@ -263,7 +264,7 @@ describe('EpicsSelect', () => {
showDropdown
();
showDropdown
();
store
.
dispatch
(
'
receiveEpicsSuccess
'
,
[
mockEpic1
]);
store
.
dispatch
(
'
receiveEpicsSuccess
'
,
[
mockEpic1
]);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findAllComponents
(
GlDropdownItem
)).
toHaveLength
(
2
);
expect
(
wrapper
.
findAllComponents
(
GlDropdownItem
)).
toHaveLength
(
2
);
});
});
...
@@ -271,7 +272,7 @@ describe('EpicsSelect', () => {
...
@@ -271,7 +272,7 @@ describe('EpicsSelect', () => {
showDropdown
();
showDropdown
();
store
.
dispatch
(
'
requestEpics
'
);
store
.
dispatch
(
'
requestEpics
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
wrapper
.
findComponent
(
GlDropdown
).
findComponent
(
GlLoadingIcon
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
GlDropdown
).
findComponent
(
GlLoadingIcon
).
exists
()).
toBe
(
true
);
});
});
...
...
ee/spec/frontend/vue_shared/components/sidebar/epics_select/dropdown_value_spec.js
View file @
6979e878
import
{
GlLink
}
from
'
@gitlab/ui
'
;
import
{
GlLink
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
DropdownValue
from
'
ee/vue_shared/components/sidebar/epics_select/dropdown_value.vue
'
;
import
DropdownValue
from
'
ee/vue_shared/components/sidebar/epics_select/dropdown_value.vue
'
;
import
{
mockEpic1
}
from
'
../mock_data
'
;
import
{
mockEpic1
}
from
'
../mock_data
'
;
...
@@ -30,14 +31,13 @@ describe('EpicsSelect', () => {
...
@@ -30,14 +31,13 @@ describe('EpicsSelect', () => {
expect
(
wrapper
.
vm
.
hasEpic
).
toBe
(
true
);
expect
(
wrapper
.
vm
.
hasEpic
).
toBe
(
true
);
});
});
it
(
'
should return `false` when provided `epic` prop is an invalid Epic object
'
,
()
=>
{
it
(
'
should return `false` when provided `epic` prop is an invalid Epic object
'
,
async
()
=>
{
wrapper
.
setProps
({
wrapper
.
setProps
({
epic
:
{},
epic
:
{},
});
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
vm
.
hasEpic
).
toBe
(
false
);
expect
(
wrapper
.
vm
.
hasEpic
).
toBe
(
false
);
});
});
});
});
});
});
});
...
@@ -57,17 +57,16 @@ describe('EpicsSelect', () => {
...
@@ -57,17 +57,16 @@ describe('EpicsSelect', () => {
expect
(
titleEl
.
text
()).
toBe
(
mockEpic1
.
title
);
expect
(
titleEl
.
text
()).
toBe
(
mockEpic1
.
title
);
});
});
it
(
'
should render no value element with slot contents when `hasEpic` is false
'
,
()
=>
{
it
(
'
should render no value element with slot contents when `hasEpic` is false
'
,
async
()
=>
{
wrapper
.
setProps
({
wrapper
.
setProps
({
epic
:
{},
epic
:
{},
});
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
const
noValueEl
=
wrapper
.
find
(
'
span.no-value
'
);
const
noValueEl
=
wrapper
.
find
(
'
span.no-value
'
);
expect
(
noValueEl
.
exists
()).
toBe
(
true
);
expect
(
noValueEl
.
exists
()).
toBe
(
true
);
expect
(
noValueEl
.
text
()).
toBe
(
'
None
'
);
expect
(
noValueEl
.
text
()).
toBe
(
'
None
'
);
});
});
});
});
});
});
});
...
...
ee/spec/frontend/vue_shared/license_compliance/components/delete_confirmation_modal_spec.js
View file @
6979e878
import
{
GlModal
,
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
GlModal
,
GlSprintf
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
Vuex
from
'
vuex
'
;
import
Vuex
from
'
vuex
'
;
import
Component
from
'
ee/vue_shared/license_compliance/components/delete_confirmation_modal.vue
'
;
import
Component
from
'
ee/vue_shared/license_compliance/components/delete_confirmation_modal.vue
'
;
import
{
approvedLicense
}
from
'
../mock_data
'
;
import
{
approvedLicense
}
from
'
../mock_data
'
;
...
@@ -98,13 +98,13 @@ describe('DeleteConfirmationModal', () => {
...
@@ -98,13 +98,13 @@ describe('DeleteConfirmationModal', () => {
describe
(
'
interaction
'
,
()
=>
{
describe
(
'
interaction
'
,
()
=>
{
it
(
'
triggering resetLicenseInModal on cancel
'
,
async
()
=>
{
it
(
'
triggering resetLicenseInModal on cancel
'
,
async
()
=>
{
findModal
().
vm
.
$emit
(
'
cancel
'
,
mockEvent
);
findModal
().
vm
.
$emit
(
'
cancel
'
,
mockEvent
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
actions
.
resetLicenseInModal
).
toHaveBeenCalled
();
expect
(
actions
.
resetLicenseInModal
).
toHaveBeenCalled
();
});
});
it
(
'
triggering deleteLicense on cancel
'
,
async
()
=>
{
it
(
'
triggering deleteLicense on cancel
'
,
async
()
=>
{
findModal
().
vm
.
$emit
(
'
primary
'
,
mockEvent
);
findModal
().
vm
.
$emit
(
'
primary
'
,
mockEvent
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
actions
.
deleteLicense
).
toHaveBeenCalled
();
expect
(
actions
.
deleteLicense
).
toHaveBeenCalled
();
});
});
});
});
...
...
ee/spec/frontend/vue_shared/license_compliance/license_management_spec.js
View file @
6979e878
import
{
GlButton
,
GlLoadingIcon
,
GlIcon
,
GlPopover
}
from
'
@gitlab/ui
'
;
import
{
GlButton
,
GlLoadingIcon
,
GlIcon
,
GlPopover
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
Vuex
from
'
vuex
'
;
import
Vuex
from
'
vuex
'
;
import
LicenseComplianceApprovals
from
'
ee/approvals/components/license_compliance/index.vue
'
;
import
LicenseComplianceApprovals
from
'
ee/approvals/components/license_compliance/index.vue
'
;
import
AddLicenseForm
from
'
ee/vue_shared/license_compliance/components/add_license_form.vue
'
;
import
AddLicenseForm
from
'
ee/vue_shared/license_compliance/components/add_license_form.vue
'
;
...
@@ -127,7 +127,7 @@ describe('License Management', () => {
...
@@ -127,7 +127,7 @@ describe('License Management', () => {
describe
(
'
permission based functionality
'
,
()
=>
{
describe
(
'
permission based functionality
'
,
()
=>
{
describe
(
'
when admin
'
,
()
=>
{
describe
(
'
when admin
'
,
()
=>
{
it
(
'
should invoke `setLicenseApproval` action on `addLicense` event on form only
'
,
()
=>
{
it
(
'
should invoke `setLicenseApproval` action on `addLicense` event on form only
'
,
async
()
=>
{
const
setLicenseApprovalMock
=
jest
.
fn
();
const
setLicenseApprovalMock
=
jest
.
fn
();
createComponent
({
createComponent
({
state
:
{
isLoadingManagedLicenses
:
false
},
state
:
{
isLoadingManagedLicenses
:
false
},
...
@@ -136,10 +136,9 @@ describe('License Management', () => {
...
@@ -136,10 +136,9 @@ describe('License Management', () => {
});
});
wrapper
.
findComponent
(
GlButton
).
vm
.
$emit
(
'
click
'
);
wrapper
.
findComponent
(
GlButton
).
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
wrapper
.
findComponent
(
AddLicenseForm
).
vm
.
$emit
(
'
addLicense
'
);
wrapper
.
findComponent
(
AddLicenseForm
).
vm
.
$emit
(
'
addLicense
'
);
expect
(
setLicenseApprovalMock
).
toHaveBeenCalled
();
expect
(
setLicenseApprovalMock
).
toHaveBeenCalled
();
});
});
});
describe
(
'
when not loading
'
,
()
=>
{
describe
(
'
when not loading
'
,
()
=>
{
...
@@ -151,13 +150,12 @@ describe('License Management', () => {
...
@@ -151,13 +150,12 @@ describe('License Management', () => {
expect
(
wrapper
.
findComponent
(
LicenseComplianceApprovals
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
LicenseComplianceApprovals
).
exists
()).
toBe
(
true
);
});
});
it
(
'
should render the form if the form is open and disable the form button
'
,
()
=>
{
it
(
'
should render the form if the form is open and disable the form button
'
,
async
()
=>
{
wrapper
.
findComponent
(
GlButton
).
vm
.
$emit
(
'
click
'
);
wrapper
.
findComponent
(
GlButton
).
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
findComponent
(
AddLicenseForm
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
AddLicenseForm
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
findComponent
(
GlButton
).
attributes
(
'
disabled
'
)).
toBe
(
'
true
'
);
expect
(
wrapper
.
findComponent
(
GlButton
).
attributes
(
'
disabled
'
)).
toBe
(
'
true
'
);
});
});
});
it
(
'
should not render the form if the form is closed and have active button
'
,
()
=>
{
it
(
'
should not render the form if the form is closed and have active button
'
,
()
=>
{
...
...
ee/spec/frontend/vue_shared/security_reports/components/dismiss_button_spec.js
View file @
6979e878
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/dismiss_button.vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/dismiss_button.vue
'
;
describe
(
'
DismissalButton
'
,
()
=>
{
describe
(
'
DismissalButton
'
,
()
=>
{
...
@@ -21,22 +22,20 @@ describe('DismissalButton', () => {
...
@@ -21,22 +22,20 @@ describe('DismissalButton', () => {
expect
(
wrapper
.
text
()).
toBe
(
'
Dismiss vulnerability
'
);
expect
(
wrapper
.
text
()).
toBe
(
'
Dismiss vulnerability
'
);
});
});
it
(
'
should emit dismiss vulnerability when clicked
'
,
()
=>
{
it
(
'
should emit dismiss vulnerability when clicked
'
,
async
()
=>
{
wrapper
.
findComponent
(
GlButton
).
trigger
(
'
click
'
);
wrapper
.
findComponent
(
GlButton
).
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
dismissVulnerability
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
dismissVulnerability
).
toBeTruthy
();
});
});
});
it
(
'
should render the dismiss with comment button
'
,
()
=>
{
it
(
'
should render the dismiss with comment button
'
,
()
=>
{
expect
(
wrapper
.
find
(
'
.js-dismiss-with-comment
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
.js-dismiss-with-comment
'
).
exists
()).
toBe
(
true
);
});
});
it
(
'
should emit openDismissalCommentBox when clicked
'
,
()
=>
{
it
(
'
should emit openDismissalCommentBox when clicked
'
,
async
()
=>
{
wrapper
.
find
(
'
.js-dismiss-with-comment
'
).
trigger
(
'
click
'
);
wrapper
.
find
(
'
.js-dismiss-with-comment
'
).
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
openDismissalCommentBox
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
openDismissalCommentBox
).
toBeTruthy
();
});
});
});
});
});
...
@@ -52,11 +51,10 @@ describe('DismissalButton', () => {
...
@@ -52,11 +51,10 @@ describe('DismissalButton', () => {
expect
(
wrapper
.
text
()).
toBe
(
'
Undo dismiss
'
);
expect
(
wrapper
.
text
()).
toBe
(
'
Undo dismiss
'
);
});
});
it
(
'
should emit revertDismissVulnerability when clicked
'
,
()
=>
{
it
(
'
should emit revertDismissVulnerability when clicked
'
,
async
()
=>
{
wrapper
.
findComponent
(
GlButton
).
trigger
(
'
click
'
);
wrapper
.
findComponent
(
GlButton
).
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
revertDismissVulnerability
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
revertDismissVulnerability
).
toBeTruthy
();
});
});
});
it
(
'
should not render the dismiss with comment button
'
,
()
=>
{
it
(
'
should not render the dismiss with comment button
'
,
()
=>
{
...
...
ee/spec/frontend/vue_shared/security_reports/components/dismissal_comment_box_spec.js
View file @
6979e878
import
{
GlFormTextarea
}
from
'
@gitlab/ui
'
;
import
{
GlFormTextarea
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/dismissal_comment_box.vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/dismissal_comment_box.vue
'
;
describe
(
'
DismissalCommentBox
'
,
()
=>
{
describe
(
'
DismissalCommentBox
'
,
()
=>
{
...
@@ -18,31 +19,28 @@ describe('DismissalCommentBox', () => {
...
@@ -18,31 +19,28 @@ describe('DismissalCommentBox', () => {
expect
(
wrapper
.
emitted
().
clearError
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
clearError
).
toBeTruthy
();
});
});
it
(
'
should submit the comment when cmd+enter is pressed
'
,
()
=>
{
it
(
'
should submit the comment when cmd+enter is pressed
'
,
async
()
=>
{
wrapper
.
findComponent
(
GlFormTextarea
).
trigger
(
'
keydown.enter
'
,
{
wrapper
.
findComponent
(
GlFormTextarea
).
trigger
(
'
keydown.enter
'
,
{
metaKey
:
true
,
metaKey
:
true
,
});
});
return
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
submit
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
submit
).
toBeTruthy
();
});
});
});
it
(
'
should render the error message
'
,
()
=>
{
it
(
'
should render the error message
'
,
async
()
=>
{
const
errorMessage
=
'
You did something wrong
'
;
const
errorMessage
=
'
You did something wrong
'
;
wrapper
.
setProps
({
errorMessage
});
wrapper
.
setProps
({
errorMessage
});
return
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
find
(
'
.js-error
'
).
text
()).
toBe
(
errorMessage
);
expect
(
wrapper
.
find
(
'
.js-error
'
).
text
()).
toBe
(
errorMessage
);
});
});
});
it
(
'
should render the placeholder
'
,
()
=>
{
it
(
'
should render the placeholder
'
,
async
()
=>
{
const
placeholder
=
'
Please type into the box
'
;
const
placeholder
=
'
Please type into the box
'
;
wrapper
.
setProps
({
placeholder
});
wrapper
.
setProps
({
placeholder
});
return
wrapper
.
vm
.
$nextTick
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
findComponent
(
GlFormTextarea
).
attributes
(
'
placeholder
'
)).
toBe
(
placeholder
);
expect
(
wrapper
.
findComponent
(
GlFormTextarea
).
attributes
(
'
placeholder
'
)).
toBe
(
placeholder
);
});
});
});
});
});
ee/spec/frontend/vue_shared/security_reports/components/dismissal_comment_modal_footer_spec.js
View file @
6979e878
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/dismissal_comment_modal_footer.vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/dismissal_comment_modal_footer.vue
'
;
import
Tracking
from
'
~/tracking
'
;
import
Tracking
from
'
~/tracking
'
;
...
@@ -29,24 +30,22 @@ describe('DismissalCommentModalFooter', () => {
...
@@ -29,24 +30,22 @@ describe('DismissalCommentModalFooter', () => {
expect
(
findAddAndDismissButton
().
text
()).
toBe
(
'
Add comment & dismiss
'
);
expect
(
findAddAndDismissButton
().
text
()).
toBe
(
'
Add comment & dismiss
'
);
});
});
it
(
'
should emit the "addCommentAndDismiss" event when clicked
'
,
()
=>
{
it
(
'
should emit the "addCommentAndDismiss" event when clicked
'
,
async
()
=>
{
findAddAndDismissButton
().
trigger
(
'
click
'
);
findAddAndDismissButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
addCommentAndDismiss
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
addCommentAndDismiss
).
toBeTruthy
();
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
'
_track_category_
'
,
'
_track_category_
'
,
'
click_add_comment_and_dismiss
'
,
'
click_add_comment_and_dismiss
'
,
);
);
});
});
});
it
(
'
should emit the cancel event when the cancel button is clicked
'
,
()
=>
{
it
(
'
should emit the cancel event when the cancel button is clicked
'
,
async
()
=>
{
wrapper
.
find
(
'
.js-cancel
'
).
trigger
(
'
click
'
);
wrapper
.
find
(
'
.js-cancel
'
).
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
cancel
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
cancel
).
toBeTruthy
();
});
});
});
});
});
...
@@ -63,13 +62,12 @@ describe('DismissalCommentModalFooter', () => {
...
@@ -63,13 +62,12 @@ describe('DismissalCommentModalFooter', () => {
expect
(
findAddAndDismissButton
().
text
()).
toBe
(
'
Add comment
'
);
expect
(
findAddAndDismissButton
().
text
()).
toBe
(
'
Add comment
'
);
});
});
it
(
'
should emit the "addCommentAndDismiss" event when clicked
'
,
()
=>
{
it
(
'
should emit the "addCommentAndDismiss" event when clicked
'
,
async
()
=>
{
findAddAndDismissButton
().
trigger
(
'
click
'
);
findAddAndDismissButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
addDismissalComment
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
addDismissalComment
).
toBeTruthy
();
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
'
_track_category_
'
,
'
click_add_comment
'
);
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
'
_track_category_
'
,
'
click_add_comment
'
);
});
});
});
});
});
...
@@ -86,13 +84,12 @@ describe('DismissalCommentModalFooter', () => {
...
@@ -86,13 +84,12 @@ describe('DismissalCommentModalFooter', () => {
expect
(
findAddAndDismissButton
().
text
()).
toBe
(
'
Save comment
'
);
expect
(
findAddAndDismissButton
().
text
()).
toBe
(
'
Save comment
'
);
});
});
it
(
'
should emit the "addCommentAndDismiss" event when clicked
'
,
()
=>
{
it
(
'
should emit the "addCommentAndDismiss" event when clicked
'
,
async
()
=>
{
findAddAndDismissButton
().
trigger
(
'
click
'
);
findAddAndDismissButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
addDismissalComment
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
addDismissalComment
).
toBeTruthy
();
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
'
_track_category_
'
,
'
click_edit_comment
'
);
expect
(
Tracking
.
event
).
toHaveBeenCalledWith
(
'
_track_category_
'
,
'
click_edit_comment
'
);
});
});
});
});
});
});
});
...
...
ee/spec/frontend/vue_shared/security_reports/components/event_item_spec.js
View file @
6979e878
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
shallowMountExtended
,
mountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
shallowMountExtended
,
mountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
Component
from
'
ee/vue_shared/security_reports/components/event_item.vue
'
;
import
Component
from
'
ee/vue_shared/security_reports/components/event_item.vue
'
;
import
NoteHeader
from
'
~/notes/components/note_header.vue
'
;
import
NoteHeader
from
'
~/notes/components/note_header.vue
'
;
...
@@ -96,19 +97,14 @@ describe('Event Item', () => {
...
@@ -96,19 +97,14 @@ describe('Event Item', () => {
expect
(
wrapper
.
element
).
toMatchSnapshot
();
expect
(
wrapper
.
element
).
toMatchSnapshot
();
});
});
it
(
'
emits the button events when clicked
'
,
()
=>
{
it
(
'
emits the button events when clicked
'
,
async
()
=>
{
const
buttons
=
wrapper
.
findAllComponents
(
GlButton
);
const
buttons
=
wrapper
.
findAllComponents
(
GlButton
);
buttons
.
at
(
0
).
trigger
(
'
click
'
);
buttons
.
at
(
0
).
trigger
(
'
click
'
);
return
wrapper
.
vm
await
nextTick
();
.
$nextTick
()
buttons
.
at
(
1
).
trigger
(
'
click
'
);
.
then
(()
=>
{
await
nextTick
();
buttons
.
at
(
1
).
trigger
(
'
click
'
);
expect
(
propsData
.
actionButtons
[
0
].
onClick
).
toHaveBeenCalledTimes
(
1
);
return
wrapper
.
vm
.
$nextTick
();
expect
(
propsData
.
actionButtons
[
1
].
onClick
).
toHaveBeenCalledTimes
(
1
);
})
.
then
(()
=>
{
expect
(
propsData
.
actionButtons
[
0
].
onClick
).
toHaveBeenCalledTimes
(
1
);
expect
(
propsData
.
actionButtons
[
1
].
onClick
).
toHaveBeenCalledTimes
(
1
);
});
});
});
});
});
});
});
ee/spec/frontend/vue_shared/security_reports/components/modal_footer_spec.js
View file @
6979e878
import
{
GlIcon
}
from
'
@gitlab/ui
'
;
import
{
GlIcon
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
DismissButton
from
'
ee/vue_shared/security_reports/components/dismiss_button.vue
'
;
import
DismissButton
from
'
ee/vue_shared/security_reports/components/dismiss_button.vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/modal_footer.vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/modal_footer.vue
'
;
import
SplitButton
from
'
ee/vue_shared/security_reports/components/split_button.vue
'
;
import
SplitButton
from
'
ee/vue_shared/security_reports/components/split_button.vue
'
;
...
@@ -40,12 +41,11 @@ describe('Security Reports modal footer', () => {
...
@@ -40,12 +41,11 @@ describe('Security Reports modal footer', () => {
expect
(
findActionButton
().
text
()).
toBe
(
'
Create issue
'
);
expect
(
findActionButton
().
text
()).
toBe
(
'
Create issue
'
);
});
});
it
(
'
emits createIssue when create issue button is clicked
'
,
()
=>
{
it
(
'
emits createIssue when create issue button is clicked
'
,
async
()
=>
{
findActionButton
().
trigger
(
'
click
'
);
findActionButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
createNewIssue
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
createNewIssue
).
toBeTruthy
();
});
});
});
});
});
...
@@ -95,12 +95,11 @@ describe('Security Reports modal footer', () => {
...
@@ -95,12 +95,11 @@ describe('Security Reports modal footer', () => {
expect
(
findActionButton
().
text
()).
toBe
(
'
Resolve with merge request
'
);
expect
(
findActionButton
().
text
()).
toBe
(
'
Resolve with merge request
'
);
});
});
it
(
'
emits createMergeRequest when create merge request button is clicked
'
,
()
=>
{
it
(
'
emits createMergeRequest when create merge request button is clicked
'
,
async
()
=>
{
findActionButton
().
trigger
(
'
click
'
);
findActionButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
createMergeRequest
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
createMergeRequest
).
toBeTruthy
();
});
});
});
});
});
...
@@ -118,12 +117,11 @@ describe('Security Reports modal footer', () => {
...
@@ -118,12 +117,11 @@ describe('Security Reports modal footer', () => {
expect
(
findActionButton
().
text
()).
toBe
(
'
Download patch to resolve
'
);
expect
(
findActionButton
().
text
()).
toBe
(
'
Download patch to resolve
'
);
});
});
it
(
'
emits downloadPatch when download patch button is clicked
'
,
()
=>
{
it
(
'
emits downloadPatch when download patch button is clicked
'
,
async
()
=>
{
findActionButton
().
trigger
(
'
click
'
);
findActionButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
emitted
().
downloadPatch
).
toBeTruthy
();
expect
(
wrapper
.
emitted
().
downloadPatch
).
toBeTruthy
();
});
});
});
});
});
...
...
ee/spec/frontend/vue_shared/security_reports/components/solution_card_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
SolutionCard
from
'
ee/vue_shared/security_reports/components/solution_card.vue
'
;
import
SolutionCard
from
'
ee/vue_shared/security_reports/components/solution_card.vue
'
;
import
{
s__
}
from
'
~/locale
'
;
import
{
s__
}
from
'
~/locale
'
;
...
@@ -57,9 +58,9 @@ describe('Solution Card', () => {
...
@@ -57,9 +58,9 @@ describe('Solution Card', () => {
});
});
describe
(
'
with download patch
'
,
()
=>
{
describe
(
'
with download patch
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
wrapper
.
setProps
({
hasDownload
:
true
});
wrapper
.
setProps
({
hasDownload
:
true
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
renders the create a merge request to implement this solution message
'
,
()
=>
{
it
(
'
renders the create a merge request to implement this solution message
'
,
()
=>
{
...
...
ee/spec/frontend/vue_shared/security_reports/components/solution_card_vuex_spec.js
View file @
6979e878
import
{
GlCard
}
from
'
@gitlab/ui
'
;
import
{
GlCard
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/solution_card_vuex.vue
'
;
import
component
from
'
ee/vue_shared/security_reports/components/solution_card_vuex.vue
'
;
import
{
s__
}
from
'
~/locale
'
;
import
{
s__
}
from
'
~/locale
'
;
...
@@ -78,16 +78,15 @@ describe('Solution Card', () => {
...
@@ -78,16 +78,15 @@ describe('Solution Card', () => {
});
});
describe
(
'
with download patch
'
,
()
=>
{
describe
(
'
with download patch
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(
async
()
=>
{
wrapper
.
setProps
({
hasDownload
:
true
});
wrapper
.
setProps
({
hasDownload
:
true
});
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
});
});
it
(
'
does not render the download and apply solution message when there is a file download and a merge request already exists
'
,
()
=>
{
it
(
'
does not render the download and apply solution message when there is a file download and a merge request already exists
'
,
async
()
=>
{
wrapper
.
setProps
({
hasMr
:
true
});
wrapper
.
setProps
({
hasMr
:
true
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
wrapper
.
find
(
'
.card-footer
'
).
exists
()).
toBe
(
false
);
expect
(
wrapper
.
find
(
'
.card-footer
'
).
exists
()).
toBe
(
false
);
});
});
});
it
(
'
renders the create a merge request to implement this solution message
'
,
()
=>
{
it
(
'
renders the create a merge request to implement this solution message
'
,
()
=>
{
...
...
ee/spec/frontend/vue_shared/survey_banner/survey_banner_spec.js
View file @
6979e878
import
{
GlBanner
,
GlButton
}
from
'
@gitlab/ui
'
;
import
{
GlBanner
,
GlButton
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
SharedSurveyBanner
from
'
ee/vue_shared/survey_banner/survey_banner.vue
'
;
import
SharedSurveyBanner
from
'
ee/vue_shared/survey_banner/survey_banner.vue
'
;
import
{
extendedWrapper
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
extendedWrapper
}
from
'
helpers/vue_test_utils_helper
'
;
import
LocalStorageSync
from
'
~/vue_shared/components/local_storage_sync.vue
'
;
import
LocalStorageSync
from
'
~/vue_shared/components/local_storage_sync.vue
'
;
...
@@ -77,7 +78,7 @@ describe('Shared Survey Banner component', () => {
...
@@ -77,7 +78,7 @@ describe('Shared Survey Banner component', () => {
async
({
localStorageValue
,
isShown
})
=>
{
async
({
localStorageValue
,
isShown
})
=>
{
localStorage
.
setItem
(
TEST_LOCAL_STORAGE_KEY
,
localStorageValue
);
localStorage
.
setItem
(
TEST_LOCAL_STORAGE_KEY
,
localStorageValue
);
createWrapper
();
createWrapper
();
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findGlBanner
().
exists
()).
toBe
(
isShown
);
expect
(
findGlBanner
().
exists
()).
toBe
(
isShown
);
},
},
...
@@ -92,7 +93,7 @@ describe('Shared Survey Banner component', () => {
...
@@ -92,7 +93,7 @@ describe('Shared Survey Banner component', () => {
expect
(
findGlBanner
().
exists
()).
toBe
(
true
);
expect
(
findGlBanner
().
exists
()).
toBe
(
true
);
findAskLaterButton
().
vm
.
$emit
(
'
click
'
);
findAskLaterButton
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
date
=
new
Date
(
localStorage
.
getItem
(
TEST_LOCAL_STORAGE_KEY
));
const
date
=
new
Date
(
localStorage
.
getItem
(
TEST_LOCAL_STORAGE_KEY
));
expect
(
findGlBanner
().
exists
()).
toBe
(
false
);
expect
(
findGlBanner
().
exists
()).
toBe
(
false
);
...
@@ -104,7 +105,7 @@ describe('Shared Survey Banner component', () => {
...
@@ -104,7 +105,7 @@ describe('Shared Survey Banner component', () => {
expect
(
findGlBanner
().
exists
()).
toBe
(
true
);
expect
(
findGlBanner
().
exists
()).
toBe
(
true
);
findGlBanner
().
vm
.
$emit
(
'
close
'
);
findGlBanner
().
vm
.
$emit
(
'
close
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
findGlBanner
().
exists
()).
toBe
(
false
);
expect
(
findGlBanner
().
exists
()).
toBe
(
false
);
expect
(
localStorage
.
getItem
(
TEST_LOCAL_STORAGE_KEY
)).
toBe
(
TEST_BANNER_ID
);
expect
(
localStorage
.
getItem
(
TEST_LOCAL_STORAGE_KEY
)).
toBe
(
TEST_BANNER_ID
);
...
...
ee/spec/frontend/vulnerabilities/header_spec.js
View file @
6979e878
import
{
GlButton
,
GlBadge
}
from
'
@gitlab/ui
'
;
import
{
GlButton
,
GlBadge
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
Api
from
'
ee/api
'
;
import
Api
from
'
ee/api
'
;
...
@@ -285,11 +285,10 @@ describe('Vulnerability Header', () => {
...
@@ -285,11 +285,10 @@ describe('Vulnerability Header', () => {
expect
(
findGlButton
().
text
()).
toBe
(
'
Download patch to resolve
'
);
expect
(
findGlButton
().
text
()).
toBe
(
'
Download patch to resolve
'
);
});
});
it
(
'
emits downloadPatch when download patch button is clicked
'
,
()
=>
{
it
(
'
emits downloadPatch when download patch button is clicked
'
,
async
()
=>
{
findGlButton
().
vm
.
$emit
(
'
click
'
);
findGlButton
().
vm
.
$emit
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
download
).
toHaveBeenCalledWith
({
fileData
:
diff
,
fileName
:
`remediation.patch`
});
expect
(
download
).
toHaveBeenCalledWith
({
fileData
:
diff
,
fileName
:
`remediation.patch`
});
});
});
});
});
});
});
});
...
@@ -369,7 +368,7 @@ describe('Vulnerability Header', () => {
...
@@ -369,7 +368,7 @@ describe('Vulnerability Header', () => {
it
(
'
the resolution alert component should not be shown if when the vulnerability is already resolved
'
,
async
()
=>
{
it
(
'
the resolution alert component should not be shown if when the vulnerability is already resolved
'
,
async
()
=>
{
wrapper
.
vm
.
vulnerability
.
state
=
'
resolved
'
;
wrapper
.
vm
.
vulnerability
.
state
=
'
resolved
'
;
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
const
alert
=
findResolutionAlert
();
const
alert
=
findResolutionAlert
();
expect
(
alert
.
exists
()).
toBe
(
false
);
expect
(
alert
.
exists
()).
toBe
(
false
);
...
...
ee/spec/frontend/vulnerabilities/history_comment_editor_spec.js
View file @
6979e878
import
{
GlFormTextarea
}
from
'
@gitlab/ui
'
;
import
{
GlFormTextarea
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
nextTick
}
from
'
vue
'
;
import
HistoryCommentEditor
from
'
ee/vulnerabilities/components/history_comment_editor.vue
'
;
import
HistoryCommentEditor
from
'
ee/vulnerabilities/components/history_comment_editor.vue
'
;
describe
(
'
History Comment Editor
'
,
()
=>
{
describe
(
'
History Comment Editor
'
,
()
=>
{
...
@@ -76,7 +77,7 @@ describe('History Comment Editor', () => {
...
@@ -76,7 +77,7 @@ describe('History Comment Editor', () => {
it
(
'
disables the save button when there is no text or only whitespace in the textarea
'
,
async
()
=>
{
it
(
'
disables the save button when there is no text or only whitespace in the textarea
'
,
async
()
=>
{
createWrapper
({
initialComment
:
'
some comment
'
});
createWrapper
({
initialComment
:
'
some comment
'
});
textarea
().
vm
.
$emit
(
'
input
'
,
'
'
);
textarea
().
vm
.
$emit
(
'
input
'
,
'
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
saveButton
().
props
(
'
disabled
'
)).
toBe
(
true
);
expect
(
saveButton
().
props
(
'
disabled
'
)).
toBe
(
true
);
});
});
...
...
ee/spec/frontend/vulnerabilities/history_comment_spec.js
View file @
6979e878
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
Vue
from
'
vue
'
;
import
Vue
,
{
nextTick
}
from
'
vue
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
createNoteMutation
from
'
ee/security_dashboard/graphql/mutations/note_create.mutation.graphql
'
;
import
createNoteMutation
from
'
ee/security_dashboard/graphql/mutations/note_create.mutation.graphql
'
;
import
destroyNoteMutation
from
'
ee/security_dashboard/graphql/mutations/note_destroy.mutation.graphql
'
;
import
destroyNoteMutation
from
'
ee/security_dashboard/graphql/mutations/note_destroy.mutation.graphql
'
;
...
@@ -104,14 +104,14 @@ describe('History Comment', () => {
...
@@ -104,14 +104,14 @@ describe('History Comment', () => {
// Either the add comment button or the edit button will exist, but not both at the same time, so we'll just find
// Either the add comment button or the edit button will exist, but not both at the same time, so we'll just find
// whichever one exists and click it to show the editor.
// whichever one exists and click it to show the editor.
const
showEditView
=
()
=>
{
const
showEditView
=
async
()
=>
{
if
(
addCommentButton
().
exists
())
{
if
(
addCommentButton
().
exists
())
{
addCommentButton
().
trigger
(
'
click
'
);
addCommentButton
().
trigger
(
'
click
'
);
}
else
{
}
else
{
editButton
().
vm
.
$emit
(
'
click
'
);
editButton
().
vm
.
$emit
(
'
click
'
);
}
}
return
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
};
};
const
editAndSaveNewContent
=
async
(
content
)
=>
{
const
editAndSaveNewContent
=
async
(
content
)
=>
{
...
@@ -138,13 +138,11 @@ describe('History Comment', () => {
...
@@ -138,13 +138,11 @@ describe('History Comment', () => {
});
});
});
});
it
(
'
shows the add comment button when the cancel button is clicked in the comment editor
'
,
()
=>
{
it
(
'
shows the add comment button when the cancel button is clicked in the comment editor
'
,
async
()
=>
{
return
showEditView
()
await
showEditView
();
.
then
(()
=>
{
commentEditor
().
vm
.
$emit
(
'
onCancel
'
);
commentEditor
().
vm
.
$emit
(
'
onCancel
'
);
await
nextTick
();
return
wrapper
.
vm
.
$nextTick
();
expectAddCommentView
();
})
.
then
(
expectAddCommentView
);
});
});
});
});
...
@@ -165,37 +163,28 @@ describe('History Comment', () => {
...
@@ -165,37 +163,28 @@ describe('History Comment', () => {
});
});
});
});
it
(
'
shows the comment when the cancel button is clicked in the comment editor
'
,
()
=>
{
it
(
'
shows the comment when the cancel button is clicked in the comment editor
'
,
async
()
=>
{
return
showEditView
()
await
showEditView
();
.
then
(()
=>
{
commentEditor
().
vm
.
$emit
(
'
onCancel
'
);
commentEditor
().
vm
.
$emit
(
'
onCancel
'
);
await
nextTick
();
return
wrapper
.
vm
.
$nextTick
();
expectExistingCommentView
();
})
expect
(
eventItem
().
element
.
innerHTML
).
toContain
(
note
.
bodyHtml
);
.
then
(()
=>
{
expectExistingCommentView
();
expect
(
eventItem
().
element
.
innerHTML
).
toContain
(
note
.
bodyHtml
);
});
});
});
it
(
'
shows the delete confirmation buttons when the delete button is clicked
'
,
()
=>
{
it
(
'
shows the delete confirmation buttons when the delete button is clicked
'
,
async
()
=>
{
deleteButton
().
trigger
(
'
click
'
);
deleteButton
().
trigger
(
'
click
'
);
await
nextTick
();
return
wrapper
.
vm
.
$nextTick
().
then
(
expectDeleteConfirmView
);
expectDeleteConfirmView
(
);
});
});
it
(
'
shows the comment when the cancel button is clicked on the delete confirmation
'
,
()
=>
{
it
(
'
shows the comment when the cancel button is clicked on the delete confirmation
'
,
async
()
=>
{
deleteButton
().
trigger
(
'
click
'
);
deleteButton
().
trigger
(
'
click
'
);
return
wrapper
.
vm
await
nextTick
();
.
$nextTick
()
cancelDeleteButton
().
trigger
(
'
click
'
);
.
then
(()
=>
{
await
nextTick
();
cancelDeleteButton
().
trigger
(
'
click
'
);
expectExistingCommentView
();
return
wrapper
.
vm
.
$nextTick
();
expect
(
eventItem
().
element
.
innerHTML
).
toContain
(
note
.
bodyHtml
);
})
.
then
(()
=>
{
expectExistingCommentView
();
expect
(
eventItem
().
element
.
innerHTML
).
toContain
(
note
.
bodyHtml
);
});
});
});
});
});
...
@@ -233,7 +222,7 @@ describe('History Comment', () => {
...
@@ -233,7 +222,7 @@ describe('History Comment', () => {
createWrapper
({
propsData
});
createWrapper
({
propsData
});
await
editAndSaveNewContent
(
'
new comment
'
);
await
editAndSaveNewContent
(
'
new comment
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
commentEditor
().
props
(
'
isSaving
'
)).
toBe
(
true
);
expect
(
commentEditor
().
props
(
'
isSaving
'
)).
toBe
(
true
);
});
});
...
@@ -297,10 +286,10 @@ describe('History Comment', () => {
...
@@ -297,10 +286,10 @@ describe('History Comment', () => {
deleteButton
().
trigger
(
'
click
'
);
deleteButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
confirmDeleteButton
().
trigger
(
'
click
'
);
confirmDeleteButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
confirmDeleteButton
().
props
(
'
loading
'
)).
toBe
(
true
);
expect
(
confirmDeleteButton
().
props
(
'
loading
'
)).
toBe
(
true
);
expect
(
cancelDeleteButton
().
props
(
'
disabled
'
)).
toBe
(
true
);
expect
(
cancelDeleteButton
().
props
(
'
disabled
'
)).
toBe
(
true
);
...
@@ -313,7 +302,7 @@ describe('History Comment', () => {
...
@@ -313,7 +302,7 @@ describe('History Comment', () => {
createWrapper
({
propsData
:
{
comment
:
note
}
});
createWrapper
({
propsData
:
{
comment
:
note
}
});
deleteButton
().
trigger
(
'
click
'
);
deleteButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
confirmDeleteButton
().
trigger
(
'
click
'
);
confirmDeleteButton
().
trigger
(
'
click
'
);
expect
(
destroyNoteMutationSpy
).
toHaveBeenCalledWith
({
expect
(
destroyNoteMutationSpy
).
toHaveBeenCalledWith
({
...
@@ -327,7 +316,7 @@ describe('History Comment', () => {
...
@@ -327,7 +316,7 @@ describe('History Comment', () => {
deleteButton
().
trigger
(
'
click
'
);
deleteButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
confirmDeleteButton
().
trigger
(
'
click
'
);
confirmDeleteButton
().
trigger
(
'
click
'
);
await
waitForPromises
();
await
waitForPromises
();
...
@@ -343,7 +332,7 @@ describe('History Comment', () => {
...
@@ -343,7 +332,7 @@ describe('History Comment', () => {
deleteButton
().
trigger
(
'
click
'
);
deleteButton
().
trigger
(
'
click
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
confirmDeleteButton
().
trigger
(
'
click
'
);
confirmDeleteButton
().
trigger
(
'
click
'
);
await
waitForPromises
();
await
waitForPromises
();
...
...
ee/spec/frontend/vulnerabilities/related_issues_spec.js
View file @
6979e878
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
{
nextTick
}
from
'
vue
'
;
import
RelatedIssues
from
'
ee/vulnerabilities/components/related_issues.vue
'
;
import
RelatedIssues
from
'
ee/vulnerabilities/components/related_issues.vue
'
;
import
createFlash
from
'
~/flash
'
;
import
createFlash
from
'
~/flash
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
...
@@ -178,7 +179,7 @@ describe('Vulnerability related issues component', () => {
...
@@ -178,7 +179,7 @@ describe('Vulnerability related issues component', () => {
createWrapper
({
data
:
{
isFormVisible
:
from
}
});
createWrapper
({
data
:
{
isFormVisible
:
from
}
});
blockEmit
(
'
toggleAddRelatedIssuesForm
'
);
blockEmit
(
'
toggleAddRelatedIssuesForm
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
blockProp
(
'
isFormVisible
'
)).
toBe
(
to
);
expect
(
blockProp
(
'
isFormVisible
'
)).
toBe
(
to
);
});
});
...
@@ -191,7 +192,7 @@ describe('Vulnerability related issues component', () => {
...
@@ -191,7 +192,7 @@ describe('Vulnerability related issues component', () => {
},
},
});
});
blockEmit
(
'
addIssuableFormCancel
'
);
blockEmit
(
'
addIssuableFormCancel
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
blockProp
(
'
isFormVisible
'
)).
toBe
(
false
);
expect
(
blockProp
(
'
isFormVisible
'
)).
toBe
(
false
);
expect
(
blockProp
(
'
inputValue
'
)).
toBe
(
''
);
expect
(
blockProp
(
'
inputValue
'
)).
toBe
(
''
);
...
@@ -206,7 +207,7 @@ describe('Vulnerability related issues component', () => {
...
@@ -206,7 +207,7 @@ describe('Vulnerability related issues component', () => {
const
touchedReference
=
'
touchedReference
'
;
const
touchedReference
=
'
touchedReference
'
;
createWrapper
({
data
:
{
state
:
{
pendingReferences
}
}
});
createWrapper
({
data
:
{
state
:
{
pendingReferences
}
}
});
blockEmit
(
'
addIssuableFormInput
'
,
{
untouchedRawReferences
,
touchedReference
});
blockEmit
(
'
addIssuableFormInput
'
,
{
untouchedRawReferences
,
touchedReference
});
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
blockProp
(
'
pendingReferences
'
)).
toEqual
(
expect
(
blockProp
(
'
pendingReferences
'
)).
toEqual
(
pendingReferences
.
concat
(
untouchedRawReferences
),
pendingReferences
.
concat
(
untouchedRawReferences
),
...
@@ -217,7 +218,7 @@ describe('Vulnerability related issues component', () => {
...
@@ -217,7 +218,7 @@ describe('Vulnerability related issues component', () => {
it
(
'
processes pending references
'
,
async
()
=>
{
it
(
'
processes pending references
'
,
async
()
=>
{
createWrapper
();
createWrapper
();
blockEmit
(
'
addIssuableFormBlur
'
,
'
135 246
'
);
blockEmit
(
'
addIssuableFormBlur
'
,
'
135 246
'
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
blockProp
(
'
pendingReferences
'
)).
toEqual
([
'
135
'
,
'
246
'
]);
expect
(
blockProp
(
'
pendingReferences
'
)).
toEqual
([
'
135
'
,
'
246
'
]);
expect
(
blockProp
(
'
inputValue
'
)).
toBe
(
''
);
expect
(
blockProp
(
'
inputValue
'
)).
toBe
(
''
);
...
@@ -226,7 +227,7 @@ describe('Vulnerability related issues component', () => {
...
@@ -226,7 +227,7 @@ describe('Vulnerability related issues component', () => {
it
(
'
removes pending reference
'
,
async
()
=>
{
it
(
'
removes pending reference
'
,
async
()
=>
{
createWrapper
({
data
:
{
state
:
{
pendingReferences
:
[
'
135
'
,
'
246
'
,
'
357
'
]
}
}
});
createWrapper
({
data
:
{
state
:
{
pendingReferences
:
[
'
135
'
,
'
246
'
,
'
357
'
]
}
}
});
blockEmit
(
'
pendingIssuableRemoveRequest
'
,
1
);
blockEmit
(
'
pendingIssuableRemoveRequest
'
,
1
);
await
wrapper
.
vm
.
$
nextTick
();
await
nextTick
();
expect
(
blockProp
(
'
pendingReferences
'
)).
toEqual
([
'
135
'
,
'
357
'
]);
expect
(
blockProp
(
'
pendingReferences
'
)).
toEqual
([
'
135
'
,
'
357
'
]);
});
});
...
...
ee/spec/frontend/vulnerabilities/vulnerability_state_dropdown_spec.js
View file @
6979e878
import
{
GlDropdown
}
from
'
@gitlab/ui
'
;
import
{
GlDropdown
}
from
'
@gitlab/ui
'
;
import
{
nextTick
}
from
'
vue
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
VulnerabilityStateDropdown
from
'
ee/vulnerabilities/components/vulnerability_state_dropdown.vue
'
;
import
VulnerabilityStateDropdown
from
'
ee/vulnerabilities/components/vulnerability_state_dropdown.vue
'
;
import
{
VULNERABILITY_STATE_OBJECTS
}
from
'
ee/vulnerabilities/constants
'
;
import
{
VULNERABILITY_STATE_OBJECTS
}
from
'
ee/vulnerabilities/constants
'
;
...
@@ -51,17 +52,16 @@ describe('Vulnerability state dropdown component', () => {
...
@@ -51,17 +52,16 @@ describe('Vulnerability state dropdown component', () => {
it
.
each
(
vulnerabilityStateObjects
)(
it
.
each
(
vulnerabilityStateObjects
)(
`when the %s dropdown item is clicked, it's the only one that's selected`
,
`when the %s dropdown item is clicked, it's the only one that's selected`
,
({
state
})
=>
{
async
({
state
})
=>
{
// Start off with an unknown state so we can click through each item and see it change.
// Start off with an unknown state so we can click through each item and see it change.
createWrapper
(
'
some unknown state
'
);
createWrapper
(
'
some unknown state
'
);
const
dropdownItem
=
dropdownItemFor
(
state
);
const
dropdownItem
=
dropdownItemFor
(
state
);
dropdownItem
.
trigger
(
'
click
'
);
dropdownItem
.
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
dropdownItems
().
wrappers
.
forEach
((
item
)
=>
{
dropdownItems
().
wrappers
.
forEach
((
item
)
=>
{
expect
(
isSelected
(
item
)).
toBe
(
item
.
attributes
(
'
data-testid
'
)
===
state
);
expect
(
isSelected
(
item
)).
toBe
(
item
.
attributes
(
'
data-testid
'
)
===
state
);
});
});
});
},
},
);
);
...
@@ -70,78 +70,67 @@ describe('Vulnerability state dropdown component', () => {
...
@@ -70,78 +70,67 @@ describe('Vulnerability state dropdown component', () => {
describe
(
'
tests that use the default wrapper
'
,
()
=>
{
describe
(
'
tests that use the default wrapper
'
,
()
=>
{
beforeEach
(()
=>
createWrapper
());
beforeEach
(()
=>
createWrapper
());
it
(
'
the save button should be enabled/disabled based on if the selected item has changed or not
'
,
()
=>
{
it
(
'
the save button should be enabled/disabled based on if the selected item has changed or not
'
,
async
()
=>
{
const
originalItem
=
selectedItem
();
const
originalItem
=
selectedItem
();
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button starts off as disabled.
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button starts off as disabled.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
return
wrapper
.
vm
await
nextTick
();
.
$nextTick
()
expect
(
isDisabled
(
saveButton
())).
toBe
(
false
);
// Check that the save button has been enabled.
.
then
(()
=>
{
originalItem
.
trigger
(
'
click
'
);
// Re-select the original item.
expect
(
isDisabled
(
saveButton
())).
toBe
(
false
);
// Check that the save button has been enabled.
originalItem
.
trigger
(
'
click
'
);
// Re-select the original item.
await
nextTick
();
return
wrapper
.
vm
.
$nextTick
();
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button has once again been disabled.
})
.
then
(()
=>
{
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button has once again been disabled.
});
});
});
it
(
'
clicking on the save button will close the dropdown and fire a change event
'
,
()
=>
{
it
(
'
clicking on the save button will close the dropdown and fire a change event
'
,
async
()
=>
{
createWrapper
();
createWrapper
();
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button starts off disabled.
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button starts off disabled.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
saveButton
().
vm
.
$emit
(
'
click
'
);
// Click on the save button.
saveButton
().
vm
.
$emit
(
'
click
'
);
// Click on the save button.
const
changeEvent
=
wrapper
.
emitted
(
'
change
'
);
const
changeEvent
=
wrapper
.
emitted
(
'
change
'
);
expect
(
wrapper
.
vm
.
$refs
.
dropdown
.
hide
).
toHaveBeenCalledTimes
(
1
);
// Check that the dropdown hide function was called.
expect
(
wrapper
.
vm
.
$refs
.
dropdown
.
hide
).
toHaveBeenCalledTimes
(
1
);
// Check that the dropdown hide function was called.
expect
(
changeEvent
).
toHaveLength
(
1
);
// Check that a change event was emitted.
expect
(
changeEvent
).
toHaveLength
(
1
);
// Check that a change event was emitted.
expect
(
changeEvent
[
0
][
0
]).
toBeTruthy
();
// Check that the change event has been emitted with something as its first parameter.
expect
(
changeEvent
[
0
][
0
]).
toBeTruthy
();
// Check that the change event has been emitted with something as its first parameter.
});
});
});
it
(
'
clicking on the cancel button will close the dropdown without emitting any events
'
,
()
=>
{
it
(
'
clicking on the cancel button will close the dropdown without emitting any events
'
,
async
()
=>
{
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button starts out disabled.
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button starts out disabled.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
isDisabled
(
saveButton
())).
toBe
(
false
);
// Check that the save button is enabled.
expect
(
isDisabled
(
saveButton
())).
toBe
(
false
);
// Check that the save button is enabled.
cancelButton
().
vm
.
$emit
(
'
click
'
);
// Click on the cancel button.
cancelButton
().
vm
.
$emit
(
'
click
'
);
// Click on the cancel button.
expect
(
Object
.
keys
(
wrapper
.
emitted
())).
toHaveLength
(
0
);
// Check that no events have been emitted.
expect
(
Object
.
keys
(
wrapper
.
emitted
())).
toHaveLength
(
0
);
// Check that no events have been emitted.
expect
(
wrapper
.
vm
.
$refs
.
dropdown
.
hide
).
toHaveBeenCalledTimes
(
1
);
// Check that hide was called on the inner dropdown.
expect
(
wrapper
.
vm
.
$refs
.
dropdown
.
hide
).
toHaveBeenCalledTimes
(
1
);
// Check that hide was called on the inner dropdown.
});
});
});
it
(
'
when the dropdown is closed, the selected item resets back to the initial item
'
,
()
=>
{
it
(
'
when the dropdown is closed, the selected item resets back to the initial item
'
,
async
()
=>
{
const
initialSelectedItem
=
selectedItem
();
const
initialSelectedItem
=
selectedItem
();
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
firstUnselectedItem
().
trigger
(
'
click
'
);
// Click on an unselected item.
return
wrapper
.
vm
await
nextTick
();
.
$nextTick
()
expect
(
selectedItem
().
element
).
not
.
toBe
(
initialSelectedItem
.
element
);
// Check that the selected item actually changed.
.
then
(()
=>
{
innerDropdown
().
vm
.
$emit
(
'
hide
'
);
// Emit the dropdown hide event.
expect
(
selectedItem
().
element
).
not
.
toBe
(
initialSelectedItem
.
element
);
// Check that the selected item actually changed.
innerDropdown
().
vm
.
$emit
(
'
hide
'
);
// Emit the dropdown hide event.
await
nextTick
();
return
wrapper
.
vm
.
$nextTick
();
expect
(
selectedItem
().
element
).
toBe
(
initialSelectedItem
.
element
);
// Check that the selected item has been reset back to the initial item.
})
.
then
(()
=>
{
expect
(
selectedItem
().
element
).
toBe
(
initialSelectedItem
.
element
);
// Check that the selected item has been reset back to the initial item.
});
});
});
it
(
'
when the parent component changes the state, the dropdown will update its selected and initial item
'
,
()
=>
{
it
(
'
when the parent component changes the state, the dropdown will update its selected and initial item
'
,
async
()
=>
{
const
stateObject
=
vulnerabilityStateObjects
[
1
];
const
stateObject
=
vulnerabilityStateObjects
[
1
];
wrapper
.
setProps
({
initialState
:
stateObject
.
state
});
// Change the state.
wrapper
.
setProps
({
initialState
:
stateObject
.
state
});
// Change the state.
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
await
nextTick
();
expect
(
innerDropdown
().
props
(
'
text
'
)).
toBe
(
stateObject
.
buttonText
);
// Check that the dropdown button's value matches the initial state.
expect
(
innerDropdown
().
props
(
'
text
'
)).
toBe
(
stateObject
.
buttonText
);
// Check that the dropdown button's value matches the initial state.
expect
(
selectedItem
().
text
()).
toMatch
(
stateObject
.
dropdownText
);
// Check that the selected item is the initial state.
expect
(
selectedItem
().
text
()).
toMatch
(
stateObject
.
dropdownText
);
// Check that the selected item is the initial state.
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button is disabled.
expect
(
isDisabled
(
saveButton
())).
toBe
(
true
);
// Check that the save button is disabled.
});
});
});
});
});
});
});
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