Commit 10139b88 authored by Jose Ivan Vargas's avatar Jose Ivan Vargas

Merge branch '327391-module-location' into 'master'

Add module-name component for generic security reports

See merge request gitlab-org/gitlab!62447
parents ff814b89 6144a4a1
...@@ -7,6 +7,7 @@ export const REPORT_TYPES = { ...@@ -7,6 +7,7 @@ export const REPORT_TYPES = {
namedList: 'named-list', namedList: 'named-list',
text: 'text', text: 'text',
value: 'value', value: 'value',
moduleLocation: 'module-location',
}; };
const REPORT_TYPE_TO_COMPONENT_MAP = { const REPORT_TYPE_TO_COMPONENT_MAP = {
...@@ -16,6 +17,7 @@ const REPORT_TYPE_TO_COMPONENT_MAP = { ...@@ -16,6 +17,7 @@ const REPORT_TYPE_TO_COMPONENT_MAP = {
[REPORT_TYPES.namedList]: () => import('./named_list.vue'), [REPORT_TYPES.namedList]: () => import('./named_list.vue'),
[REPORT_TYPES.text]: () => import('./value.vue'), [REPORT_TYPES.text]: () => import('./value.vue'),
[REPORT_TYPES.value]: () => import('./value.vue'), [REPORT_TYPES.value]: () => import('./value.vue'),
[REPORT_TYPES.moduleLocation]: () => import('./module_location.vue'),
}; };
export const getComponentNameForType = (reportType) => export const getComponentNameForType = (reportType) =>
......
<script>
export default {
inheritAttrs: false,
props: {
moduleName: {
type: String,
required: true,
},
offset: {
type: Number,
required: true,
},
},
};
</script>
<template>
<span>{{ moduleName }}:{{ offset }}</span>
</template>
...@@ -25,6 +25,10 @@ const TEST_DATA = { ...@@ -25,6 +25,10 @@ const TEST_DATA = {
name: 'some-numeric-field', name: 'some-numeric-field',
value: 15, value: 15,
}, },
[REPORT_TYPES.moduleName]: {
'module-name': 'foo.c',
offset: 15,
},
}; };
describe('ee/vulnerabilities/components/generic_report/report_item.vue', () => { describe('ee/vulnerabilities/components/generic_report/report_item.vue', () => {
......
import { shallowMount } from '@vue/test-utils';
import ModuleLocation from 'ee/vulnerabilities/components/generic_report/types/module_location.vue';
describe('ee/vulnerabilities/components/generic_report/types/module_location.vue', () => {
let wrapper;
describe.each`
moduleName | offset | value
${'foo.c'} | ${4} | ${'foo.c:4'}
${'bar.go'} | ${2} | ${'bar.go:2'}
`('with value of type "$fieldType"', ({ moduleName, offset, value }) => {
const createWrapper = () => {
return shallowMount(ModuleLocation, {
propsData: {
type: 'module-location',
moduleName,
offset,
},
});
};
beforeEach(() => {
wrapper = createWrapper();
});
afterEach(() => {
wrapper.destroy();
});
it(`renders ${moduleName} module`, () => {
expect(wrapper.text()).toBe(value.toString());
});
});
});
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