mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-25 15:15:19 +00:00
fix(nuxt): don't override payload error if it is present (#7290)
This commit is contained in:
parent
86158bb407
commit
1ca294e125
@ -124,7 +124,8 @@ export default defineRenderHandler(async (event) => {
|
|||||||
const renderer = (process.env.NUXT_NO_SSR || ssrContext.noSSR) ? await getSPARenderer() : await getSSRRenderer()
|
const renderer = (process.env.NUXT_NO_SSR || ssrContext.noSSR) ? await getSPARenderer() : await getSSRRenderer()
|
||||||
const _rendered = await renderer.renderToString(ssrContext).catch((err) => {
|
const _rendered = await renderer.renderToString(ssrContext).catch((err) => {
|
||||||
if (!ssrError) {
|
if (!ssrError) {
|
||||||
throw err
|
// Use explicitly thrown error in preference to subsequent rendering errors
|
||||||
|
throw ssrContext.payload?.error || err
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
await ssrContext.nuxt?.hooks.callHook('app:rendered', { ssrContext })
|
await ssrContext.nuxt?.hooks.callHook('app:rendered', { ssrContext })
|
||||||
|
@ -202,30 +202,6 @@ describe('navigate external', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('errors', () => {
|
|
||||||
it('should render a JSON error page', async () => {
|
|
||||||
const res = await fetch('/error', {
|
|
||||||
headers: {
|
|
||||||
accept: 'application/json'
|
|
||||||
}
|
|
||||||
})
|
|
||||||
expect(res.status).toBe(500)
|
|
||||||
const error = await res.json()
|
|
||||||
delete error.stack
|
|
||||||
expect(error).toMatchObject({
|
|
||||||
message: 'This is a custom error',
|
|
||||||
statusCode: 500,
|
|
||||||
statusMessage: 'Internal Server Error',
|
|
||||||
url: '/error'
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('should render a HTML error page', async () => {
|
|
||||||
const res = await fetch('/error')
|
|
||||||
expect(await res.text()).toContain('This is a custom error')
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('middlewares', () => {
|
describe('middlewares', () => {
|
||||||
it('should redirect to index with global middleware', async () => {
|
it('should redirect to index with global middleware', async () => {
|
||||||
const html = await $fetch('/redirect/')
|
const html = await $fetch('/redirect/')
|
||||||
@ -592,3 +568,28 @@ describe('useAsyncData', () => {
|
|||||||
await expectNoClientErrors('/useAsyncData/promise-all')
|
await expectNoClientErrors('/useAsyncData/promise-all')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// TODO: Move back up after https://github.com/vuejs/core/issues/6110 is resolved
|
||||||
|
describe('errors', () => {
|
||||||
|
it('should render a JSON error page', async () => {
|
||||||
|
const res = await fetch('/error', {
|
||||||
|
headers: {
|
||||||
|
accept: 'application/json'
|
||||||
|
}
|
||||||
|
})
|
||||||
|
expect(res.status).toBe(422)
|
||||||
|
const error = await res.json()
|
||||||
|
delete error.stack
|
||||||
|
expect(error).toMatchObject({
|
||||||
|
message: 'This is a custom error',
|
||||||
|
statusCode: 422,
|
||||||
|
statusMessage: 'This is a custom error',
|
||||||
|
url: '/error'
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should render a HTML error page', async () => {
|
||||||
|
const res = await fetch('/error')
|
||||||
|
expect(await res.text()).toContain('This is a custom error')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
15
test/fixtures/basic/pages/error.vue
vendored
15
test/fixtures/basic/pages/error.vue
vendored
@ -1,7 +1,18 @@
|
|||||||
<template>
|
<template>
|
||||||
<div />
|
<div>
|
||||||
|
{{ state.attr }}
|
||||||
|
{{ data.something }}
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
throw new Error('This is a custom error')
|
const { data, error } = await useAsyncData(() => {
|
||||||
|
throw new Error('some error')
|
||||||
|
}, { server: true })
|
||||||
|
|
||||||
|
if (error.value) {
|
||||||
|
throw createError({ statusCode: 422, fatal: true, statusMessage: 'This is a custom error' })
|
||||||
|
}
|
||||||
|
|
||||||
|
const state = ref({ attr: 'Hello World' })
|
||||||
</script>
|
</script>
|
||||||
|
Loading…
Reference in New Issue
Block a user