mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-26 23:52:06 +00:00
60 lines
1.5 KiB
TypeScript
60 lines
1.5 KiB
TypeScript
|
import { describe, expect, it } from 'vitest'
|
||
|
import type { Plugin } from 'vite'
|
||
|
import { DevOnlyPlugin } from '../src/core/plugins/dev-only'
|
||
|
import { normalizeLineEndings } from './utils'
|
||
|
const pluginVite = DevOnlyPlugin.raw({}, { framework: 'vite' }) as Plugin
|
||
|
|
||
|
const viteTransform = async (source: string, id: string) => {
|
||
|
const result = await (pluginVite.transform! as Function)(source, id)
|
||
|
return typeof result === 'string' ? result : result?.code
|
||
|
}
|
||
|
|
||
|
describe('test devonly transform ', () => {
|
||
|
it('test dev only treeshaking', async () => {
|
||
|
const result = await viteTransform(`<template>
|
||
|
<div>
|
||
|
<LazyDevOnly>
|
||
|
<SomeDevOnlyComponent></SomeDevOnlyComponent>
|
||
|
</LazyDevOnly>
|
||
|
</div>
|
||
|
<SomeComponent>
|
||
|
<lazy-dev-only>
|
||
|
test
|
||
|
</lazy-dev-only>
|
||
|
</SomeComponent>
|
||
|
<div>
|
||
|
<DevOnly>
|
||
|
<SomeDevOnlyComponent></SomeDevOnlyComponent>
|
||
|
</DevOnly>
|
||
|
</div>
|
||
|
<SomeComponent>
|
||
|
<dev-only>
|
||
|
test
|
||
|
</dev-only>
|
||
|
</SomeComponent>
|
||
|
</template>`, 'some id')
|
||
|
|
||
|
expect(normalizeLineEndings(result)).toMatchInlineSnapshot(`
|
||
|
"<template>
|
||
|
<div>
|
||
|
|
||
|
</div>
|
||
|
<SomeComponent>
|
||
|
|
||
|
</SomeComponent>
|
||
|
<div>
|
||
|
|
||
|
</div>
|
||
|
<SomeComponent>
|
||
|
|
||
|
</SomeComponent>
|
||
|
</template>"
|
||
|
`)
|
||
|
|
||
|
expect(result).not.toContain('dev-only')
|
||
|
expect(result).not.toContain('DevOnly')
|
||
|
expect(result).not.toContain('lazy-dev-only')
|
||
|
expect(result).not.toContain('LazyDevOnly')
|
||
|
})
|
||
|
})
|