summaryrefslogtreecommitdiff
path: root/spec/frontend/diffs/components/merge_conflict_warning_spec.js
blob: 4e47249f5b4de3cf2e00501aee92df985401d94e (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
import { shallowMount, mount } from '@vue/test-utils';
import MergeConflictWarning from '~/diffs/components/merge_conflict_warning.vue';

const propsData = {
  limited: true,
  mergeable: true,
  resolutionPath: 'a-path',
};

function findResolveButton(wrapper) {
  return wrapper.find('.gl-alert-actions a.gl-button:first-child');
}
function findLocalMergeButton(wrapper) {
  return wrapper.find('.gl-alert-actions button.gl-button:last-child');
}

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

  const createComponent = (props = {}, { full } = { full: false }) => {
    const mounter = full ? mount : shallowMount;

    wrapper = mounter(MergeConflictWarning, {
      propsData: { ...propsData, ...props },
    });
  };

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

  it.each`
    present  | resolutionPath
    ${false} | ${''}
    ${true}  | ${'some-path'}
  `(
    'toggles the resolve conflicts button based on the provided resolutionPath "$resolutionPath"',
    ({ present, resolutionPath }) => {
      createComponent({ resolutionPath }, { full: true });
      const resolveButton = findResolveButton(wrapper);

      expect(resolveButton.exists()).toBe(present);
      if (present) {
        expect(resolveButton.attributes('href')).toBe(resolutionPath);
      }
    },
  );

  it.each`
    present  | mergeable
    ${false} | ${false}
    ${true}  | ${true}
  `(
    'toggles the local merge button based on the provided mergeable property "$mergable"',
    ({ present, mergeable }) => {
      createComponent({ mergeable }, { full: true });
      const localMerge = findLocalMergeButton(wrapper);

      expect(localMerge.exists()).toBe(present);
    },
  );
});