Nuxt/test/spa-loader/spa-preloader-outside-disabled.test.ts

46 lines
1.4 KiB
TypeScript
Raw Normal View History

2024-11-07 18:09:29 +00:00
import { fileURLToPath } from 'node:url'
import { describe, expect, it } from 'vitest'
import { isWindows } from 'std-env'
import { $fetch, getBrowser, setup, url } from '@nuxt/test-utils'
const isWebpack =
process.env.TEST_BUILDER === 'webpack' ||
process.env.TEST_BUILDER === 'rspack'
2024-12-09 12:46:26 +00:00
const isDev = process.env.TEST_ENV === 'dev'
2024-11-07 18:09:29 +00:00
await setup({
rootDir: fileURLToPath(new URL('../fixtures/spa-loader', import.meta.url)),
2024-12-09 12:46:26 +00:00
dev: isDev,
2024-11-07 18:09:29 +00:00
server: true,
browser: true,
setupTimeout: (isWindows ? 360 : 120) * 1000,
nuxtConfig: {
builder: isWebpack ? 'webpack' : 'vite',
spaLoadingTemplate: true,
experimental: {
spaLoadingTemplateLocation: 'within',
2024-11-07 18:09:29 +00:00
},
},
})
describe('spaLoadingTemplateLocation flag is set to `within`', () => {
2024-11-07 18:09:29 +00:00
it('shoul be render loader inside appTag', async () => {
2024-12-09 12:48:48 +00:00
const html = await $fetch<string>('/spa')
2024-12-09 12:52:49 +00:00
expect(html.replace(/[\n\r]+/g, '')).toContain(
2024-12-09 12:48:48 +00:00
`<div id="__nuxt"><div data-testid="loader">loading...</div></div>`,
2024-12-01 09:52:19 +00:00
)
2024-11-07 18:09:29 +00:00
})
2024-12-09 12:46:26 +00:00
it.skipIf(isDev)('spa-loader does not appear while the app is mounting', async () => {
const browser = await getBrowser()
const page = await browser.newPage({})
await page.goto(url('/spa'), { waitUntil: 'domcontentloaded' })
2024-11-07 18:09:29 +00:00
2024-12-09 12:46:26 +00:00
const loader = page.getByTestId('loader')
expect(await loader.isHidden()).toBeTruthy()
2024-11-07 18:09:29 +00:00
2024-12-09 12:46:26 +00:00
await page.close()
}, 60_000)
2024-11-07 18:09:29 +00:00
})