summaryrefslogtreecommitdiff
path: root/spec/javascripts/vue_shared/components/markdown/suggestions_spec.js
blob: 33be63a3a1e48ad744f22231d3047a78c7a5bfbf (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
119
120
121
122
123
124
125
import Vue from 'vue';
import SuggestionsComponent from '~/vue_shared/components/markdown/suggestions.vue';

const MOCK_DATA = {
  fromLine: 1,
  fromContent: 'Old content',
  suggestions: [],
  noteHtml: `
    <div class="suggestion">
      <div class="line">Suggestion 1</div>
    </div>    
    
    <div class="suggestion">
      <div class="line">Suggestion 2</div>
    </div>
  `,
  isApplied: false,
  helpPagePath: 'path_to_docs',
};

const generateLine = content => {
  const line = document.createElement('div');
  line.className = 'line';
  line.innerHTML = content;

  return line;
};

const generateMockLines = () => {
  const line1 = generateLine('Line 1');
  const line2 = generateLine('Line 2');
  const line3 = generateLine('- Line 3');
  const container = document.createElement('div');

  container.appendChild(line1);
  container.appendChild(line2);
  container.appendChild(line3);

  return container;
};

describe('Suggestion component', () => {
  let vm;
  let extractedLines;
  let diffTable;

  beforeEach(done => {
    const Component = Vue.extend(SuggestionsComponent);

    vm = new Component({
      propsData: MOCK_DATA,
    }).$mount();

    extractedLines = vm.extractNewLines(generateMockLines());
    diffTable = vm.generateDiff(extractedLines).$mount().$el;

    spyOn(vm, 'renderSuggestions');
    vm.renderSuggestions();
    Vue.nextTick(done);
  });

  describe('mounted', () => {
    it('renders a flash container', () => {
      expect(vm.$el.querySelector('.js-suggestions-flash')).not.toBeNull();
    });

    it('renders a container for suggestions', () => {
      expect(vm.$refs.container).not.toBeNull();
    });

    it('renders suggestions', () => {
      expect(vm.renderSuggestions).toHaveBeenCalled();
      expect(vm.$el.innerHTML.includes('Suggestion 1')).toBe(true);
      expect(vm.$el.innerHTML.includes('Suggestion 2')).toBe(true);
    });
  });

  describe('extractNewLines', () => {
    it('extracts suggested lines', () => {
      const expectedReturn = [
        { content: 'Line 1\n', lineNumber: 1 },
        { content: 'Line 2\n', lineNumber: 2 },
        { content: '- Line 3\n', lineNumber: 3 },
      ];

      expect(vm.extractNewLines(generateMockLines())).toEqual(expectedReturn);
    });

    it('increments line number for each extracted line', () => {
      expect(extractedLines[0].lineNumber).toEqual(1);
      expect(extractedLines[1].lineNumber).toEqual(2);
      expect(extractedLines[2].lineNumber).toEqual(3);
    });

    it('returns empty array if no lines are found', () => {
      const el = document.createElement('div');

      expect(vm.extractNewLines(el)).toEqual([]);
    });
  });

  describe('generateDiff', () => {
    it('generates a diff table', () => {
      expect(diffTable.querySelector('.md-suggestion-diff')).not.toBeNull();
    });

    it('generates a diff table that contains contents of `oldLineContent`', () => {
      expect(diffTable.innerHTML.includes(vm.fromContent)).toBe(true);
    });

    it('generates a diff table that contains contents the suggested lines', () => {
      extractedLines.forEach((line, i) => {
        expect(diffTable.innerHTML.includes(extractedLines[i].content)).toBe(true);
      });
    });

    it('generates a diff table with the correct line number for each suggested line', () => {
      const lines = diffTable.getElementsByClassName('qa-new-diff-line-number');

      expect([...lines][0].innerHTML).toBe('1');
      expect([...lines][1].innerHTML).toBe('2');
      expect([...lines][2].innerHTML).toBe('3');
    });
  });
});