2019-04-11 13:14:27 +01:00
|
|
|
const cssMatcher = require('jest-matcher-css')
|
|
|
|
const defaultConfig = require('tailwindcss/defaultConfig')
|
2019-05-01 19:40:39 +01:00
|
|
|
const plugin = require('./index')
|
2019-04-11 13:14:27 +01:00
|
|
|
const postcss = require('postcss')
|
|
|
|
const tailwindcss = require('tailwindcss')
|
|
|
|
|
2019-04-11 20:59:01 +01:00
|
|
|
const generatePluginCss = (options = {}) => {
|
2019-04-11 13:14:27 +01:00
|
|
|
return postcss(
|
|
|
|
tailwindcss({
|
2019-04-23 21:41:38 +01:00
|
|
|
corePlugins: false,
|
2019-04-11 20:59:01 +01:00
|
|
|
plugins: [plugin(options)]
|
2019-04-11 13:14:27 +01:00
|
|
|
})
|
|
|
|
)
|
|
|
|
.process('@tailwind utilities;', {
|
|
|
|
from: undefined
|
|
|
|
})
|
2019-05-01 19:38:06 +01:00
|
|
|
.then(result => result.css)
|
2019-04-11 13:14:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
expect.extend({
|
|
|
|
toMatchCss: cssMatcher
|
|
|
|
})
|
|
|
|
|
2019-04-11 20:59:01 +01:00
|
|
|
test('it generates the correct classes with no variants', () => {
|
2019-04-11 13:14:27 +01:00
|
|
|
return generatePluginCss().then(css => {
|
|
|
|
expect(css).toMatchCss(`
|
|
|
|
.test {
|
2019-04-23 21:41:00 +01:00
|
|
|
display: block
|
2019-04-11 13:14:27 +01:00
|
|
|
}
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
})
|
2019-04-11 20:59:01 +01:00
|
|
|
|
|
|
|
test('it generates the correct classes with variants', () => {
|
|
|
|
return generatePluginCss({ variants: ['hover', 'focus'] }).then(css => {
|
|
|
|
expect(css).toMatchCss(`
|
|
|
|
.test {
|
2019-04-23 21:41:00 +01:00
|
|
|
display: block
|
2019-04-11 20:59:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
.hover\\:test:hover {
|
2019-04-23 21:41:00 +01:00
|
|
|
display: block
|
2019-04-11 20:59:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
.focus\\:test:focus {
|
2019-04-23 21:41:00 +01:00
|
|
|
display: block
|
2019-04-11 20:59:01 +01:00
|
|
|
}
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
})
|