summaryrefslogtreecommitdiff
path: root/spec/frontend/static_site_editor/components/saved_changes_message_spec.js
blob: 76ac7de5c3256a17aa325f1cd439634eb71104cc (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
import { shallowMount } from '@vue/test-utils';
import SavedChangesMessage from '~/static_site_editor/components/saved_changes_message.vue';

describe('~/static_site_editor/components/saved_changes_message.vue', () => {
  let wrapper;
  const props = {
    branch: {
      label: '123-the-branch',
      url: 'https://gitlab.com/gitlab-org/gitlab/-/tree/123-the-branch',
    },
    commit: {
      label: 'a123',
      url: 'https://gitlab.com/gitlab-org/gitlab/-/commit/a123',
    },
    mergeRequest: {
      label: '123',
      url: 'https://gitlab.com/gitlab-org/gitlab/-/merge_requests/123',
    },
    returnUrl: 'https://www.the-static-site.com/post',
  };
  const findReturnToSiteButton = () => wrapper.find({ ref: 'returnToSiteButton' });
  const findMergeRequestButton = () => wrapper.find({ ref: 'mergeRequestButton' });
  const findBranchLink = () => wrapper.find({ ref: 'branchLink' });
  const findCommitLink = () => wrapper.find({ ref: 'commitLink' });
  const findMergeRequestLink = () => wrapper.find({ ref: 'mergeRequestLink' });

  beforeEach(() => {
    wrapper = shallowMount(SavedChangesMessage, {
      propsData: props,
    });
  });

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

  it.each`
    text                    | findEl                    | url
    ${'Return to site'}     | ${findReturnToSiteButton} | ${props.returnUrl}
    ${'View merge request'} | ${findMergeRequestButton} | ${props.mergeRequest.url}
  `('renders "$text" button link', ({ text, findEl, url }) => {
    const btn = findEl();

    expect(btn.exists()).toBe(true);
    expect(btn.text()).toBe(text);
    expect(btn.attributes('href')).toBe(url);
  });

  it.each`
    desc               | findEl                  | prop
    ${'branch'}        | ${findBranchLink}       | ${props.branch}
    ${'commit'}        | ${findCommitLink}       | ${props.commit}
    ${'merge request'} | ${findMergeRequestLink} | ${props.mergeRequest}
  `('renders $desc link', ({ findEl, prop }) => {
    const el = findEl();

    expect(el.exists()).toBe(true);
    expect(el.attributes('href')).toBe(prop.url);
    expect(el.text()).toBe(prop.label);
  });
});