summaryrefslogtreecommitdiff
path: root/spec/frontend/vue_shared/components/content_viewer/content_viewer_spec.js
blob: 16e7e4dd5cc7a86cd18102df1dcff8c1be8dcc88 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import { mount } from '@vue/test-utils';
import { GREEN_BOX_IMAGE_URL } from 'spec/test_constants';
import ContentViewer from '~/vue_shared/components/content_viewer/content_viewer.vue';
import '~/behaviors/markdown/render_gfm';

describe('ContentViewer', () => {
  let wrapper;

  it.each`
    path                   | type          | selector           | viewer
    ${GREEN_BOX_IMAGE_URL} | ${'image'}    | ${'img'}           | ${'<image-viewer>'}
    ${'myfile.md'}         | ${'markdown'} | ${'.md-previewer'} | ${'<markdown-viewer>'}
    ${'myfile.abc'}        | ${undefined}  | ${'[download]'}    | ${'<download-viewer>'}
  `('renders $viewer when file type="$type"', ({ path, type, selector }) => {
    wrapper = mount(ContentViewer, {
      propsData: { path, fileSize: 1024, type },
    });

    expect(wrapper.find(selector).element).toExist();
  });
});