Skip to content

Commit

Permalink
tests
Browse files Browse the repository at this point in the history
  • Loading branch information
yyx990803 committed Jan 31, 2017
1 parent bf2fa0b commit 55d3b98
Show file tree
Hide file tree
Showing 13 changed files with 2,155 additions and 31 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
/node_modules
.DS_Store
/node_modules
4 changes: 0 additions & 4 deletions fixtures/a.css

This file was deleted.

4 changes: 0 additions & 4 deletions fixtures/b.css

This file was deleted.

3 changes: 0 additions & 3 deletions fixtures/base.css

This file was deleted.

3 changes: 0 additions & 3 deletions fixtures/c.css

This file was deleted.

3 changes: 0 additions & 3 deletions fixtures/entry.js

This file was deleted.

7 changes: 0 additions & 7 deletions fixtures/webpack.config.js

This file was deleted.

9 changes: 7 additions & 2 deletions lib/addStylesClient.js
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,10 @@ module.exports = function (parentId, list, _isProduction) {
mayRemove.push(domStyle)
}
if (newList) {
var newStyles = listToStyles(parentId, newList)
addStylesToDom(newStyles)
styles = listToStyles(parentId, newList)
addStylesToDom(styles)
} else {
styles = []
}
for (var i = 0; i < mayRemove.length; i++) {
var domStyle = mayRemove[i]
Expand All @@ -89,6 +91,9 @@ function addStylesToDom (styles /* Array<StyleObject> */) {
for (; j < item.parts.length; j++) {
domStyle.parts.push(addStyle(item.parts[j]))
}
if (domStyle.parts.length > item.parts.length) {
domStyle.parts.length = item.parts.length
}
} else {
var parts = []
for (var j = 0; j < item.parts.length; j++) {
Expand Down
2 changes: 1 addition & 1 deletion lib/addStylesServer.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ function renderStyles (styles) {
css += `<style data-vue-ssr-id="${
style.ids.join(' ')
}"${
style.media ? ` media=${style.mdia}` : ''
style.media ? ` media="${style.media}"` : ''
}>${style.css}</style>`
}
return css
Expand Down
9 changes: 6 additions & 3 deletions lib/listToStyles.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,15 @@ module.exports = function listToStyles (parentId, list) {
var css = item[1]
var media = item[2]
var sourceMap = item[3]
var part = { css: css, media: media, sourceMap: sourceMap }
var part = {
id: parentId + ':' + i,
css: css,
media: media,
sourceMap: sourceMap
}
if (!newStyles[id]) {
part.id = parentId + ':0'
styles.push(newStyles[id] = { id: id, parts: [part] })
} else {
part.id = parentId + ':' + newStyles[id].parts.length
newStyles[id].parts.push(part)
}
}
Expand Down
6 changes: 6 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,15 @@
"type": "git",
"url": "[email protected]:vuejs/vue-style-loader.git"
},
"scripts": {
"test": "jest"
},
"license": "MIT",
"dependencies": {
"hash-sum": "^1.0.2",
"loader-utils": "^0.2.7"
},
"devDependencies": {
"jest": "^18.1.0"
}
}
94 changes: 94 additions & 0 deletions test/test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,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)
}
Loading

0 comments on commit 55d3b98

Please sign in to comment.