Commit cd80a0e4 authored by Mark Florian's avatar Mark Florian

Merge branch '218451-sd-filters-specs-vtu-refactor' into 'master'

Use VTU in filters specs

Closes #218451

See merge request gitlab-org/gitlab!32860
parents aee71022 9ad7b72b
import Vue from 'vue'; import Vuex from 'vuex';
import component from 'ee/security_dashboard/components/filters.vue'; import Filters from 'ee/security_dashboard/components/filters.vue';
import createStore from 'ee/security_dashboard/store'; import createStore from 'ee/security_dashboard/store';
import { mountComponentWithStore } from 'helpers/vue_mount_component_helper'; import { mount, createLocalVue } from '@vue/test-utils';
const localVue = createLocalVue();
localVue.use(Vuex);
describe('Filter component', () => { describe('Filter component', () => {
let vm; let wrapper;
const store = createStore(); let store;
const Component = Vue.extend(component);
const findReportTypeFilter = () => wrapper.find('.js-filter-report_type');
const createWrapper = (props = {}) => {
wrapper = mount(Filters, {
localVue,
store,
propsData: {
...props,
},
});
};
beforeEach(() => {
store = createStore();
});
afterEach(() => { afterEach(() => {
vm.$destroy(); wrapper.destroy();
wrapper = null;
}); });
describe('severity', () => { describe('severity', () => {
beforeEach(() => { beforeEach(() => {
vm = mountComponentWithStore(Component, { store }); createWrapper();
}); });
it('should display all filters', () => { it('should display all filters', () => {
expect(vm.$el.querySelectorAll('.js-filter')).toHaveLength(3); expect(wrapper.findAll('.js-filter')).toHaveLength(3);
}); });
it('should display "Hide dismissed vulnerabilities" toggle', () => { it('should display "Hide dismissed vulnerabilities" toggle', () => {
expect(vm.$el.querySelectorAll('.js-toggle')).toHaveLength(1); expect(wrapper.findAll('.js-toggle')).toHaveLength(1);
}); });
}); });
describe('Report type', () => { describe('Report type', () => {
const findReportTypeFilter = () => vm.$el.querySelector('.js-filter-report_type');
it.each` it.each`
dastProps | string dastProps | string
${{ vulnerabilitiesCount: 0, scannedResourcesCount: 123 }} | ${'(0 vulnerabilities, 123 urls scanned)'} ${{ vulnerabilitiesCount: 0, scannedResourcesCount: 123 }} | ${'(0 vulnerabilities, 123 urls scanned)'}
...@@ -39,15 +56,12 @@ describe('Filter component', () => { ...@@ -39,15 +56,12 @@ describe('Filter component', () => {
${{ vulnerabilitiesCount: 0 }} | ${'(0 vulnerabilities)'} ${{ vulnerabilitiesCount: 0 }} | ${'(0 vulnerabilities)'}
${{ scannedResourcesCount: 0 }} | ${'(0 urls scanned)'} ${{ scannedResourcesCount: 0 }} | ${'(0 urls scanned)'}
`('shows security report summary $string', ({ dastProps, string }) => { `('shows security report summary $string', ({ dastProps, string }) => {
vm = mountComponentWithStore(Component, { createWrapper({
store,
props: {
securityReportSummary: { securityReportSummary: {
dast: dastProps, dast: dastProps,
}, },
},
}); });
expect(findReportTypeFilter().textContent).toContain(string); expect(findReportTypeFilter().text()).toContain(string);
}); });
}); });
}); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment