summaryrefslogtreecommitdiff
path: root/spec/frontend/static_site_editor/components/edit_drawer_spec.js
blob: c47eef59997aa732b9896cd18c8cc37ff44c4091 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import { shallowMount } from '@vue/test-utils';

import { GlDrawer } from '@gitlab/ui';

import EditDrawer from '~/static_site_editor/components/edit_drawer.vue';
import FrontMatterControls from '~/static_site_editor/components/front_matter_controls.vue';

describe('~/static_site_editor/components/edit_drawer.vue', () => {
  let wrapper;

  const buildWrapper = (propsData = {}) => {
    wrapper = shallowMount(EditDrawer, {
      propsData: {
        isOpen: false,
        settings: { title: 'Some title' },
        ...propsData,
      },
    });
  };

  const findFrontMatterControls = () => wrapper.find(FrontMatterControls);
  const findGlDrawer = () => wrapper.find(GlDrawer);

  beforeEach(() => {
    buildWrapper();
  });

  afterEach(() => {
    wrapper.destroy();
    wrapper = null;
  });

  it('renders the GlDrawer', () => {
    expect(findGlDrawer().exists()).toBe(true);
  });

  it('renders the FrontMatterControls', () => {
    expect(findFrontMatterControls().exists()).toBe(true);
  });

  it('forwards the settings to FrontMatterControls', () => {
    expect(findFrontMatterControls().props('settings')).toBe(wrapper.props('settings'));
  });

  it('is closed by default', () => {
    expect(findGlDrawer().props('open')).toBe(false);
  });

  it('can open', () => {
    buildWrapper({ isOpen: true });

    expect(findGlDrawer().props('open')).toBe(true);
  });

  it.each`
    event               | payload             | finderFn
    ${'close'}          | ${undefined}        | ${findGlDrawer}
    ${'updateSettings'} | ${{ some: 'data' }} | ${findFrontMatterControls}
  `(
    'forwards the emitted $event event from the $finderFn with $payload',
    ({ event, payload, finderFn }) => {
      finderFn().vm.$emit(event, payload);

      expect(wrapper.emitted(event)[0][0]).toBe(payload);
      expect(wrapper.emitted(event).length).toBe(1);
    },
  );
});