summaryrefslogtreecommitdiff
path: root/spec/javascripts/matchers.js
blob: 0d465510fd3611f02d0d6f67d484e4610a367efc (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
export default {
  toContainText: () => ({
    compare(vm, text) {
      if (!(vm.$el instanceof HTMLElement)) {
        throw new Error('vm.$el is not a DOM element!');
      }

      const result = {
        pass: vm.$el.innerText.includes(text),
      };
      return result;
    },
  }),
  toHaveSpriteIcon: () => ({
    compare(element, iconName) {
      if (!iconName) {
        throw new Error('toHaveSpriteIcon is missing iconName argument!');
      }

      if (!(element instanceof HTMLElement)) {
        throw new Error(`${element} is not a DOM element!`);
      }

      const iconReferences = [].slice.apply(element.querySelectorAll('svg use'));
      const matchingIcon = iconReferences.find(reference =>
        reference.getAttribute('xlink:href').endsWith(`#${iconName}`),
      );
      const result = {
        pass: !!matchingIcon,
      };

      if (result.pass) {
        result.message = `${element.outerHTML} contains the sprite icon "${iconName}"!`;
      } else {
        result.message = `${element.outerHTML} does not contain the sprite icon "${iconName}"!`;

        const existingIcons = iconReferences.map(reference => {
          const iconUrl = reference.getAttribute('xlink:href');
          return `"${iconUrl.replace(/^.+#/, '')}"`;
        });
        if (existingIcons.length > 0) {
          result.message += ` (only found ${existingIcons.join(',')})`;
        }
      }

      return result;
    },
  }),
  toRender: () => ({
    compare(vm) {
      const result = {
        pass: vm.$el.nodeType !== Node.COMMENT_NODE,
      };
      return result;
    },
  }),
};