import { describe, expect, it, vi } from 'vitest'
import type { ComponentOptions } from 'vue'
import { Suspense, defineComponent, h, toDisplayString, useAttrs } from 'vue'
import { mountSuspended } from '@nuxt/test-utils/runtime'
import { flushPromises, mount } from '@vue/test-utils'
import { createClientOnly } from '../../packages/nuxt/src/app/components/client-only'
import { createClientPage } from '../../packages/nuxt/dist/components/runtime/client-component'
const Client = defineComponent({
name: 'TestClient',
setup () {
const attrs = useAttrs()
return () => h('div', {}, toDisplayString(attrs))
},
})
describe('createClient attribute inheritance', () => {
it('should retrieve attributes with useAttrs()', async () => {
const wrapper = await mountSuspended(createClientOnly(Client as ComponentOptions), {
attrs: {
id: 'client',
},
})
expect(wrapper.html()).toMatchInlineSnapshot(`
"
{
"id": "client"
}
"
`)
})
})
describe('client page', () => {
it('Should be suspensed when out of hydration', async () => {
let resolve
const promise = new Promise((_resolve) => {
resolve = _resolve
})
const comp = defineComponent({
async setup () {
await promise
return () => h('div', { id: 'async' }, 'async resolved')
},
})
const wrapper = mount({
setup () {
return () => h('div', {}, [
h(Suspense, {}, {
default: () => h(createClientPage(() => Promise.resolve(comp)), {}),
fallback: () => h('div', { id: 'fallback' }, 'loading'),
}),
])
},
})
await flushPromises()
expect(wrapper.find('#fallback').exists()).toBe(true)
expect(wrapper.find('#async').exists()).toBe(false)
resolve!()
await flushPromises()
expect(wrapper.find('#async').exists()).toBe(true)
expect(wrapper.find('#fallback').exists()).toBe(false)
})
})
describe('app/compat', () => {
const Component = defineComponent({
setup () {
const visible = ref(false)
setInterval(() => {
visible.value = true
}, 1000)
return () => h('div', {}, visible.value ? h('span', { id: 'child' }) : {})
},
})
it('setInterval is not auto-imported', async () => {
vi.useFakeTimers()
const wrapper = mount(Component)
vi.advanceTimersByTime(1000)
await wrapper.vm.$nextTick()
expect(wrapper.find('#child').exists()).toBe(true)
vi.useRealTimers()
})
})