summaryrefslogtreecommitdiff
path: root/spec/frontend/repository/pages/tree_spec.js
blob: 36662696c91b280506645f8143811dec7dba67c6 (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
import { shallowMount } from '@vue/test-utils';
import TreePage from '~/repository/pages/tree.vue';
import { updateElementsVisibility } from '~/repository/utils/dom';

jest.mock('~/repository/utils/dom');

describe('Repository tree page component', () => {
  let wrapper;

  function factory(path) {
    wrapper = shallowMount(TreePage, { propsData: { path } });
  }

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

    updateElementsVisibility.mockClear();
  });

  describe('when root path', () => {
    beforeEach(() => {
      factory('/');
    });

    it('shows root elements', () => {
      expect(updateElementsVisibility.mock.calls).toEqual([
        ['.js-show-on-root', true],
        ['.js-hide-on-root', false],
      ]);
    });

    describe('when changed', () => {
      beforeEach(() => {
        updateElementsVisibility.mockClear();

        wrapper.setProps({ path: '/test' });
      });

      it('hides root elements', () => {
        expect(updateElementsVisibility.mock.calls).toEqual([
          ['.js-show-on-root', false],
          ['.js-hide-on-root', true],
        ]);
      });
    });
  });

  describe('when non-root path', () => {
    beforeEach(() => {
      factory('/test');
    });

    it('hides root elements', () => {
      expect(updateElementsVisibility.mock.calls).toEqual([
        ['.js-show-on-root', false],
        ['.js-hide-on-root', true],
      ]);
    });
  });
});