import { ErrorBoundary, Suspense } from '@suspensive/react'
import { ERROR_MESSAGE, FALLBACK, TEXT, sleep } from '@suspensive/utils'
import { render, screen, waitFor } from '@testing-library/react'
import ms from 'ms'
import { awaitClient } from './AwaitClient'
import { useAwait } from './useAwait'
const key = (id: number) => ['key', id] as const
const AwaitSuccess = () => {
const awaited = useAwait({ key: key(1), fn: () => sleep(ms('0.1s')).then(() => TEXT) })
return (
<>
{awaited.data}
>
)
}
const AwaitFailure = () => {
const awaited = useAwait({
key: key(1),
fn: () => sleep(ms('0.1s')).then(() => Promise.reject(new Error(ERROR_MESSAGE))),
})
return <>{awaited.data}>
}
describe('useAwait', () => {
beforeEach(() => awaitClient.reset())
it('should return object containing data field with only success, and It will be cached', async () => {
const { unmount } = render(
)
expect(screen.queryByText(FALLBACK)).toBeInTheDocument()
await waitFor(() => expect(screen.queryByText(TEXT)).toBeInTheDocument())
// success data cache test
unmount()
render(
)
expect(screen.queryByText(FALLBACK)).not.toBeInTheDocument()
expect(screen.queryByText(TEXT)).toBeInTheDocument()
})
it('should throw Error, and It will be cached', async () => {
const { unmount } = render(
<>{props.error.message}>}>
)
expect(screen.queryByText(FALLBACK)).toBeInTheDocument()
await waitFor(() => expect(screen.queryByText(ERROR_MESSAGE)).toBeInTheDocument())
// error cache test
unmount()
render(
<>{props.error.message}>}>
)
expect(screen.queryByText(FALLBACK)).not.toBeInTheDocument()
expect(screen.queryByText(ERROR_MESSAGE)).toBeInTheDocument()
})
it('should return object containing reset method to reset cache by key', async () => {
const { rerender } = render(
)
expect(screen.queryByText(FALLBACK)).toBeInTheDocument()
await waitFor(() => expect(screen.queryByText(TEXT)).toBeInTheDocument())
const resetButton = await screen.findByRole('button', { name: 'Try again' })
resetButton.click()
rerender(
)
expect(screen.queryByText(FALLBACK)).toBeInTheDocument()
await waitFor(() => expect(screen.queryByText(TEXT)).toBeInTheDocument())
})
})