summaryrefslogtreecommitdiff
path: root/spec/frontend/work_items_hierarchy/components/hierarchy_spec.js
blob: 74774e38d6b36d194ca7b068b2ad6246f58562a3 (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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import { createLocalVue, mount } from '@vue/test-utils';
import VueApollo from 'vue-apollo';
import { GlBadge } from '@gitlab/ui';
import Hierarchy from '~/work_items_hierarchy/components/hierarchy.vue';
import { extendedWrapper } from 'helpers/vue_test_utils_helper';
import RESPONSE from '~/work_items_hierarchy/static_response';
import { workItemTypes } from '~/work_items_hierarchy/constants';

const localVue = createLocalVue();
localVue.use(VueApollo);

describe('WorkItemsHierarchy Hierarchy', () => {
  let wrapper;

  const workItemsFromResponse = (response) => {
    return response.reduce(
      (itemTypes, item) => {
        const key = item.available ? 'available' : 'unavailable';
        itemTypes[key].push({
          ...item,
          ...workItemTypes[item.type],
          nestedTypes: item.nestedTypes
            ? item.nestedTypes.map((type) => workItemTypes[type])
            : null,
        });
        return itemTypes;
      },
      { available: [], unavailable: [] },
    );
  };

  const createComponent = (props = {}) => {
    wrapper = extendedWrapper(
      mount(Hierarchy, {
        localVue,
        propsData: {
          workItemTypes: props.workItemTypes,
          ...props,
        },
      }),
    );
  };

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

  describe('available structure', () => {
    let items = [];

    beforeEach(() => {
      items = workItemsFromResponse(RESPONSE.ultimate).available;
      createComponent({ workItemTypes: items });
    });

    it('renders all work items', () => {
      expect(wrapper.findAllByTestId('work-item-wrapper')).toHaveLength(items.length);
    });

    it('does not render badges', () => {
      expect(wrapper.find(GlBadge).exists()).toBe(false);
    });
  });

  describe('unavailable structure', () => {
    let items = [];

    beforeEach(() => {
      items = workItemsFromResponse(RESPONSE.premium).unavailable;
      createComponent({ workItemTypes: items });
    });

    it('renders all work items', () => {
      expect(wrapper.findAllByTestId('work-item-wrapper')).toHaveLength(items.length);
    });

    it('renders license badges for all work items', () => {
      expect(wrapper.findAll(GlBadge)).toHaveLength(items.length);
    });

    it('does not render svg icon for linking', () => {
      expect(wrapper.findByTestId('hierarchy-rounded-arrow-tail').exists()).toBe(false);
      expect(wrapper.findByTestId('level-up-icon').exists()).toBe(false);
    });
  });

  describe('nested work items', () => {
    describe.each`
      licensePlan   | arrowTailVisible | levelUpIconVisible | arrowDownIconVisible
      ${'ultimate'} | ${true}          | ${true}            | ${true}
      ${'premium'}  | ${false}         | ${false}           | ${true}
      ${'free'}     | ${false}         | ${false}           | ${false}
    `(
      'when $licensePlan license',
      ({ licensePlan, arrowTailVisible, levelUpIconVisible, arrowDownIconVisible }) => {
        let items = [];
        beforeEach(() => {
          items = workItemsFromResponse(RESPONSE[licensePlan]).available;
          createComponent({ workItemTypes: items });
        });

        it(`${arrowTailVisible ? 'render' : 'does not render'} arrow tail svg`, () => {
          expect(wrapper.findByTestId('hierarchy-rounded-arrow-tail').exists()).toBe(
            arrowTailVisible,
          );
        });

        it(`${levelUpIconVisible ? 'render' : 'does not render'} arrow tail svg`, () => {
          expect(wrapper.findByTestId('level-up-icon').exists()).toBe(levelUpIconVisible);
        });

        it(`${arrowDownIconVisible ? 'render' : 'does not render'} arrow tail svg`, () => {
          expect(wrapper.findByTestId('arrow-down-icon').exists()).toBe(arrowDownIconVisible);
        });
      },
    );
  });
});