Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
86 lines
2.8 KiB
TypeScript
86 lines
2.8 KiB
TypeScript
/* eslint-env jest */
|
|
|
|
import { fetchViaHTTP, waitFor } from 'next-test-utils'
|
|
import path from 'path'
|
|
import { nextTestSetup } from 'e2e-utils'
|
|
|
|
describe('Client navigation on error pages', () => {
|
|
const { next } = nextTestSetup({
|
|
files: path.join(__dirname, 'fixture'),
|
|
env: {
|
|
TEST_STRICT_NEXT_HEAD: String(true),
|
|
},
|
|
})
|
|
|
|
it('should not reload when visiting /_error directly', async () => {
|
|
const { status } = await fetchViaHTTP(next.appPort, '/_error')
|
|
const browser = await next.browser('/_error')
|
|
|
|
await browser.eval('window.hello = true')
|
|
|
|
// wait on-demand-entries timeout since it can trigger
|
|
// reloading non-stop
|
|
for (let i = 0; i < 15; i++) {
|
|
expect(await browser.eval('window.hello')).toBe(true)
|
|
await waitFor(1000)
|
|
}
|
|
const html = await browser.eval('document.documentElement.innerHTML')
|
|
|
|
expect(status).toBe(404)
|
|
expect(html).toContain('This page could not be found')
|
|
expect(html).toContain('404')
|
|
})
|
|
|
|
describe('with 404 pages', () => {
|
|
it('should 404 on not existent page', async () => {
|
|
const browser = await next.browser('/non-existent')
|
|
expect(await browser.elementByCss('h1').text()).toBe('404')
|
|
expect(await browser.elementByCss('h2').text()).toBe(
|
|
'This page could not be found.'
|
|
)
|
|
await browser.close()
|
|
})
|
|
|
|
it('should 404 on wrong casing', async () => {
|
|
const browser = await next.browser('/nAv/AbOuT')
|
|
expect(await browser.elementByCss('h1').text()).toBe('404')
|
|
expect(await browser.elementByCss('h2').text()).toBe(
|
|
'This page could not be found.'
|
|
)
|
|
await browser.close()
|
|
})
|
|
|
|
it('should get url dynamic param', async () => {
|
|
const browser = await next.browser('/dynamic/dynamic-part/route')
|
|
expect(await browser.elementByCss('p').text()).toBe('dynamic-part')
|
|
await browser.close()
|
|
})
|
|
|
|
it('should 404 on wrong casing of url dynamic param', async () => {
|
|
const browser = await next.browser('/dynamic/dynamic-part/RoUtE')
|
|
expect(await browser.elementByCss('h1').text()).toBe('404')
|
|
expect(await browser.elementByCss('h2').text()).toBe(
|
|
'This page could not be found.'
|
|
)
|
|
await browser.close()
|
|
})
|
|
|
|
it('should not 404 for <page>/', async () => {
|
|
const browser = await next.browser('/nav/about/')
|
|
const text = await browser.elementByCss('p').text()
|
|
expect(text).toBe('This is the about page.')
|
|
await browser.close()
|
|
})
|
|
|
|
it('should should not contain a page script in a 404 page', async () => {
|
|
const browser = await next.browser('/non-existent')
|
|
const scripts = await browser.elementsByCss('script[src]')
|
|
for (const script of scripts) {
|
|
const src = await script.getAttribute('src')
|
|
expect(src.includes('/non-existent')).toBeFalsy()
|
|
}
|
|
await browser.close()
|
|
})
|
|
})
|
|
})
|