2022-07-16 23:28:13 +05:30
import { GlBadge } from '@gitlab/ui' ;
import { shallowMount } from '@vue/test-utils' ;
import { WorkspaceType , IssuableType } from '~/issues/constants' ;
import ConfidentialityBadge from '~/vue_shared/components/confidentiality_badge.vue' ;
const createComponent = ( {
workspaceType = WorkspaceType . project ,
issuableType = IssuableType . Issue ,
} = { } ) =>
shallowMount ( ConfidentialityBadge , {
propsData : {
workspaceType ,
issuableType ,
} ,
} ) ;
describe ( 'ConfidentialityBadge' , ( ) => {
let wrapper ;
beforeEach ( ( ) => {
wrapper = createComponent ( ) ;
} ) ;
afterEach ( ( ) => {
wrapper . destroy ( ) ;
} ) ;
it . each `
workspaceType | issuableType | expectedTooltip
2022-07-23 23:45:48 +05:30
$ { WorkspaceType . project } | $ { IssuableType . Issue } | $ { 'Only project members with at least the Reporter role, the author, and assignees can view or be notified about this issue.' }
$ { WorkspaceType . group } | $ { IssuableType . Epic } | $ { 'Only group members with at least the Reporter role can view or be notified about this epic.' }
2022-07-16 23:28:13 +05:30
` (
'should render gl-badge with correct tooltip when workspaceType is $workspaceType and issuableType is $issuableType' ,
( { workspaceType , issuableType , expectedTooltip } ) => {
wrapper = createComponent ( {
workspaceType ,
issuableType ,
} ) ;
const badgeEl = wrapper . findComponent ( GlBadge ) ;
expect ( badgeEl . props ( ) ) . toMatchObject ( {
icon : 'eye-slash' ,
variant : 'warning' ,
} ) ;
expect ( badgeEl . attributes ( 'title' ) ) . toBe ( expectedTooltip ) ;
expect ( badgeEl . text ( ) ) . toBe ( 'Confidential' ) ;
} ,
) ;
} ) ;