40 lines
1 KiB
JavaScript
40 lines
1 KiB
JavaScript
import { GlDropdown, GlDropdownItem } from '@gitlab/ui';
|
|
import { shallowMount } from '@vue/test-utils';
|
|
import Vue from 'vue';
|
|
import Vuex from 'vuex';
|
|
import PreviewDropdown from '~/batch_comments/components/preview_dropdown.vue';
|
|
import { createStore } from '~/mr_notes/stores';
|
|
import { createDraft } from '../mock_data';
|
|
|
|
jest.mock('~/behaviors/markdown/render_gfm');
|
|
|
|
Vue.use(Vuex);
|
|
|
|
describe('Batch comments publish dropdown component', () => {
|
|
let wrapper;
|
|
|
|
function createComponent() {
|
|
const store = createStore();
|
|
store.state.batchComments.drafts.push(createDraft(), { ...createDraft(), id: 2 });
|
|
|
|
wrapper = shallowMount(PreviewDropdown, {
|
|
store,
|
|
});
|
|
}
|
|
|
|
afterEach(() => {
|
|
wrapper.destroy();
|
|
});
|
|
|
|
it('renders list of drafts', () => {
|
|
createComponent();
|
|
|
|
expect(wrapper.findAllComponents(GlDropdownItem).length).toBe(2);
|
|
});
|
|
|
|
it('renders draft count in dropdown title', () => {
|
|
createComponent();
|
|
|
|
expect(wrapper.findComponent(GlDropdown).props('headerText')).toEqual('2 pending comments');
|
|
});
|
|
});
|