From 3933f246d2a0757bf4e84b3a608760ee5fe45aa8 Mon Sep 17 00:00:00 2001 From: MellowMelon Date: Wed, 25 Jan 2023 15:20:12 -0800 Subject: [PATCH] Fix hbs with layout not throwing errors correctly --- index.js | 3 ++- test/test-handlebars.js | 28 ++++++++++++++++++++++++++++ 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/index.js b/index.js index 97a913f2..81f0480c 100644 --- a/index.js +++ b/index.js @@ -732,7 +732,8 @@ function fastifyView (fastify, opts, next) { header: () => { }, send: (result) => { if (result instanceof Error) { - throw result + that.send(result) + return } data = Object.assign((data || {}), { body: result }) diff --git a/test/test-handlebars.js b/test/test-handlebars.js index 9756a08e..853676ed 100644 --- a/test/test-handlebars.js +++ b/test/test-handlebars.js @@ -413,6 +413,34 @@ test('reply.view with handlebars engine catches render error', t => { }) }) +test('reply.view with handlebars engine and layout catches render error', t => { + t.plan(3) + const fastify = Fastify() + const handlebars = require('handlebars') + + handlebars.registerHelper('badHelper', () => { throw new Error('kaboom') }) + + fastify.register(require('../index'), { + engine: { + handlebars + }, + layout: './templates/layout.hbs' + }) + + fastify.get('/', (req, reply) => { + reply.view('./templates/error.hbs') + }) + + fastify.inject({ + method: 'GET', + url: '/' + }, (err, res) => { + t.error(err) + t.equal(JSON.parse(res.body).message, 'kaboom') + t.equal(res.statusCode, 500) + }) +}) + test('reply.view with handlebars engine and defaultContext', t => { t.plan(6) const fastify = Fastify()