Blame view

node_modules/vue-style-loader/test/test.js 2.99 KB
aaac7fed   liuqimichale   add
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
  const addStylesClient = require('../lib/addStylesClient')
  const addStylesServer = require('../lib/addStylesServer')
  
  const mockedList = [
    [1, 'h1 { color: red; }', ''],
    [1, 'p { color: green; }', ''],
    [2, 'span { color: blue; }', ''],
    [2, 'span { color: blue; }', 'print']
  ]
  
  test('addStylesClient (dev)', () => {
    const update = addStylesClient('foo', mockedList, false)
    assertStylesMatch(mockedList)
    const mockedList2 = mockedList.slice(1, 3)
    update(mockedList2)
    assertStylesMatch(mockedList2)
    update()
    expect(document.querySelectorAll('style').length).toBe(0)
  })
  
  test('addStylesClient (prod)', () => {
    const update = addStylesClient('foo', mockedList, true)
    assertStylesMatch(mockedList)
    const mockedList2 = mockedList.slice(2)
    update(mockedList2)
    assertStylesMatch(mockedList2)
    update()
    expect(document.querySelectorAll('style').length).toBe(0)
  })
  
  test('addStylesClient (dev + ssr)', () => {
    mockSSRTags(mockedList, 'foo')
    const update = addStylesClient('foo', mockedList, false)
    assertStylesMatch(mockedList)
    update()
    expect(document.querySelectorAll('style').length).toBe(0)
  })
  
  test('addStylesClient (prod + ssr)', () => {
    mockProdSSRTags(mockedList, 'foo')
    const update = addStylesClient('foo', mockedList, true)
    expect(document.querySelectorAll('style').length).toBe(1)
  })
  
  test('addStylesServer (dev)', () => {
    const context = global.__VUE_SSR_CONTEXT__ = {}
    addStylesServer('foo', mockedList, false)
    expect(context.styles).toBe(
      `<style data-vue-ssr-id="foo:0">h1 { color: red; }</style>` +
      `<style data-vue-ssr-id="foo:1">p { color: green; }</style>` +
      `<style data-vue-ssr-id="foo:2">span { color: blue; }</style>` +
      `<style data-vue-ssr-id="foo:3" media="print">span { color: blue; }</style>`
    )
  })
  
  test('addStylesServer (prod)', () => {
    const context = global.__VUE_SSR_CONTEXT__ = {}
    addStylesServer('foo', mockedList, true)
    expect(context.styles).toBe(
      `<style data-vue-ssr-id="foo:0 foo:1 foo:2">` +
        `h1 { color: red; }\np { color: green; }\nspan { color: blue; }` +
      `</style>` +
      `<style data-vue-ssr-id="foo:3" media="print">span { color: blue; }</style>`
    )
  })
  
  // --- helpers ---
  
  function assertStylesMatch (list) {
    const styles = document.querySelectorAll('style')
    expect(styles.length).toBe(list.length)
    ;[].forEach.call(styles, (style, i) => {
      expect(style.textContent.indexOf(list[i][1]) > -1).toBe(true)
    })
  }
  
  function mockSSRTags (list, parentId) {
    list.forEach((item, i) => {
      const style = document.createElement('style')
      style.setAttribute('data-vue-ssr-id', `${parentId}:${i}`)
      style.textContent = item[1]
      if (item[2]) {
        style.setAttribute('media', item[2])
      }
      document.head.appendChild(style)
    })
  }
  
  function mockProdSSRTags (list, parentId) {
    const style = document.createElement('style')
    style.setAttribute('data-vue-ssr-id', list.map((item, i) => `${parentId}:${i}`).join(' '))
    style.textContent = list.map(item => item[1]).join('\n')
    document.head.appendChild(style)
  }