summaryrefslogtreecommitdiff
path: root/spec/frontend/reports/grouped_test_report/components/modal_spec.js
blob: e8564d2428d8221673e8f2132c4d5ec5a4a8dace (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 { GlLink, GlSprintf } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils';
import { extendedWrapper } from 'helpers/vue_test_utils_helper';

import ReportsModal from '~/reports/grouped_test_report/components/modal.vue';
import state from '~/reports/grouped_test_report/store/state';
import CodeBlock from '~/vue_shared/components/code_block.vue';

const StubbedGlModal = { template: '<div><slot></slot></div>', name: 'GlModal', props: ['title'] };

describe('Grouped Test Reports Modal', () => {
  const modalDataStructure = state().modal.data;
  const title = 'Test#sum when a is 1 and b is 2 returns summary';

  // populate data
  modalDataStructure.execution_time.value = 0.009411;
  modalDataStructure.system_output.value = 'Failure/Error: is_expected.to eq(3)\n\n';
  modalDataStructure.filename.value = {
    text: 'link',
    path: '/file/path',
  };

  let wrapper;

  beforeEach(() => {
    wrapper = extendedWrapper(
      shallowMount(ReportsModal, {
        propsData: {
          title,
          modalData: modalDataStructure,
          visible: true,
        },
        stubs: { GlModal: StubbedGlModal, GlSprintf },
      }),
    );
  });

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

  it('renders code block', () => {
    expect(wrapper.findComponent(CodeBlock).props().code).toEqual(
      modalDataStructure.system_output.value,
    );
  });

  it('renders link', () => {
    const link = wrapper.findComponent(GlLink);

    expect(link.attributes().href).toEqual(modalDataStructure.filename.value.path);

    expect(link.text()).toEqual(modalDataStructure.filename.value.text);
  });

  it('renders seconds', () => {
    expect(wrapper.text()).toContain(`${modalDataStructure.execution_time.value} s`);
  });

  it('render title', () => {
    expect(wrapper.findComponent(StubbedGlModal).props().title).toEqual(title);
  });

  it('re-emits hide event', () => {
    wrapper.findComponent(StubbedGlModal).vm.$emit('hide');
    expect(wrapper.emitted().hide).toEqual([[]]);
  });
});