|
|
- import addStylesClient from '../lib/addStylesClient'
- import addStylesServer from '../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)
- }
|