import { __unstable__loadDesignSystem } from '@tailwindcss/node'
import dedent from 'dedent'
import { expect, test, vi } from 'vitest'
import * as versions from '../../utils/version'
import { migrateVariantOrder } from './migrate-variant-order'
vi.spyOn(versions, 'isMajor').mockReturnValue(true)
let css = dedent
test.each([
['flex', 'flex'],
['hover:flex', 'hover:flex'],
['[color:red]', '[color:red]'],
['[&:focus]:[color:red]', '[&:focus]:[color:red]'],
['*:first:flex', 'first:*:flex'],
['data-[invalid]:data-[hover]:flex', 'data-[invalid]:data-[hover]:flex'],
['hover:focus:flex', 'hover:focus:flex'],
['focus:hover:flex', 'focus:hover:flex'],
['[&:hover]:[&:focus]:flex', '[&:hover]:[&:focus]:flex'],
['[&:focus]:[&:hover]:flex', '[&:focus]:[&:hover]:flex'],
['data-[a]:data-[b]:flex', 'data-[a]:data-[b]:flex'],
['dark:before:flex', 'dark:before:flex'],
['before:dark:flex', 'dark:before:flex'],
['dark:*:before:after:flex', 'dark:*:before:after:flex'],
['dark:before:after:*:flex', 'dark:*:before:after:flex'],
['dark:*:hover:file:focus:underline', 'dark:focus:file:hover:*:underline'],
['sm:dark:hover:flex', 'sm:dark:hover:flex'],
['[@media(print)]:group-hover:flex', '[@media(print)]:group-hover:flex'],
['sm:max-xl:data-[a]:data-[b]:dark:hover:flex', 'sm:max-xl:dark:data-[a]:data-[b]:hover:flex'],
[
'sm:data-[root]:*:data-[a]:even:*:data-[b]:even:before:underline',
'sm:even:data-[b]:*:even:data-[a]:*:data-[root]:before:underline',
],
['hover:[@supports(display:grid)]:flex', '[@supports(display:grid)]:hover:flex'],
])('%s => %s', async (candidate, result) => {
let designSystem = await __unstable__loadDesignSystem('@import "tailwindcss";', {
base: __dirname,
})
expect(migrateVariantOrder(designSystem, {}, candidate)).toEqual(result)
})
test('it works with custom variants', async () => {
let designSystem = await __unstable__loadDesignSystem(
css`
@import 'tailwindcss';
@custom-variant atrule {
@media (print) {
@slot;
}
}
@custom-variant combinator {
> * {
@slot;
}
}
@custom-variant pseudo {
&::before {
@slot;
}
}
`,
{
base: __dirname,
},
)
expect(migrateVariantOrder(designSystem, {}, 'combinator:pseudo:atrule:underline')).toEqual(
'atrule:combinator:pseudo:underline',
)
})