Aktueller Stand
This commit is contained in:
167
backend/node_modules/fastify/test/plugin.1.test.js
generated
vendored
167
backend/node_modules/fastify/test/plugin.1.test.js
generated
vendored
@@ -1,23 +1,21 @@
|
||||
'use strict'
|
||||
|
||||
/* eslint no-prototype-builtins: 0 */
|
||||
|
||||
const t = require('tap')
|
||||
const t = require('node:test')
|
||||
const test = t.test
|
||||
const Fastify = require('../fastify')
|
||||
const sget = require('simple-get').concat
|
||||
const fp = require('fastify-plugin')
|
||||
|
||||
test('require a plugin', t => {
|
||||
test('require a plugin', (t, testDone) => {
|
||||
t.plan(1)
|
||||
const fastify = Fastify()
|
||||
fastify.register(require('./plugin.helper'))
|
||||
fastify.ready(() => {
|
||||
t.ok(fastify.test)
|
||||
t.assert.ok(fastify.test)
|
||||
testDone()
|
||||
})
|
||||
})
|
||||
|
||||
test('plugin metadata - ignore prefix', t => {
|
||||
test('plugin metadata - ignore prefix', (t, testDone) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
@@ -28,8 +26,9 @@ test('plugin metadata - ignore prefix', t => {
|
||||
method: 'GET',
|
||||
url: '/'
|
||||
}, function (err, res) {
|
||||
t.error(err)
|
||||
t.equal(res.payload, 'hello')
|
||||
t.assert.ifError(err)
|
||||
t.assert.strictEqual(res.payload, 'hello')
|
||||
testDone()
|
||||
})
|
||||
|
||||
function plugin (instance, opts, done) {
|
||||
@@ -47,37 +46,37 @@ test('plugin metadata - naming plugins', async t => {
|
||||
fastify.register(require('./plugin.name.display'))
|
||||
fastify.register(function (fastify, opts, done) {
|
||||
// one line
|
||||
t.equal(fastify.pluginName, 'function (fastify, opts, done) { -- // one line')
|
||||
t.assert.strictEqual(fastify.pluginName, 'function (fastify, opts, done) { -- // one line')
|
||||
done()
|
||||
})
|
||||
fastify.register(function fooBar (fastify, opts, done) {
|
||||
t.equal(fastify.pluginName, 'fooBar')
|
||||
t.assert.strictEqual(fastify.pluginName, 'fooBar')
|
||||
done()
|
||||
})
|
||||
|
||||
await fastify.ready()
|
||||
})
|
||||
|
||||
test('fastify.register with fastify-plugin should not encapsulate his code', t => {
|
||||
t.plan(10)
|
||||
test('fastify.register with fastify-plugin should not encapsulate his code', async t => {
|
||||
t.plan(9)
|
||||
const fastify = Fastify()
|
||||
|
||||
fastify.register((instance, opts, done) => {
|
||||
instance.register(fp((i, o, n) => {
|
||||
i.decorate('test', () => {})
|
||||
t.ok(i.test)
|
||||
t.assert.ok(i.test)
|
||||
n()
|
||||
}))
|
||||
|
||||
t.notOk(instance.test)
|
||||
t.assert.ok(!instance.test)
|
||||
|
||||
// the decoration is added at the end
|
||||
instance.after(() => {
|
||||
t.ok(instance.test)
|
||||
t.assert.ok(instance.test)
|
||||
})
|
||||
|
||||
instance.get('/', (req, reply) => {
|
||||
t.ok(instance.test)
|
||||
t.assert.ok(instance.test)
|
||||
reply.send({ hello: 'world' })
|
||||
})
|
||||
|
||||
@@ -85,41 +84,36 @@ test('fastify.register with fastify-plugin should not encapsulate his code', t =
|
||||
})
|
||||
|
||||
fastify.ready(() => {
|
||||
t.notOk(fastify.test)
|
||||
t.assert.ok(!fastify.test)
|
||||
})
|
||||
|
||||
fastify.listen({ port: 0 }, err => {
|
||||
t.error(err)
|
||||
t.teardown(() => { fastify.close() })
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
sget({
|
||||
method: 'GET',
|
||||
url: 'http://localhost:' + fastify.server.address().port
|
||||
}, (err, response, body) => {
|
||||
t.error(err)
|
||||
t.equal(response.statusCode, 200)
|
||||
t.equal(response.headers['content-length'], '' + body.length)
|
||||
t.same(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
})
|
||||
const result = await fetch(fastifyServer)
|
||||
t.assert.ok(result.ok)
|
||||
t.assert.strictEqual(result.status, 200)
|
||||
const body = await result.text()
|
||||
t.assert.strictEqual(result.headers.get('content-length'), '' + body.length)
|
||||
t.assert.deepStrictEqual(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
|
||||
test('fastify.register with fastify-plugin should provide access to external fastify instance if opts argument is a function', t => {
|
||||
t.plan(22)
|
||||
test('fastify.register with fastify-plugin should provide access to external fastify instance if opts argument is a function', async t => {
|
||||
t.plan(21)
|
||||
const fastify = Fastify()
|
||||
|
||||
fastify.register((instance, opts, done) => {
|
||||
instance.register(fp((i, o, n) => {
|
||||
i.decorate('global', () => {})
|
||||
t.ok(i.global)
|
||||
t.assert.ok(i.global)
|
||||
n()
|
||||
}))
|
||||
|
||||
instance.register((i, o, n) => n(), p => {
|
||||
t.notOk(p === instance || p === fastify)
|
||||
t.ok(instance.isPrototypeOf(p))
|
||||
t.ok(fastify.isPrototypeOf(p))
|
||||
t.ok(p.global)
|
||||
t.assert.ok(!(p === instance || p === fastify))
|
||||
t.assert.ok(Object.prototype.isPrototypeOf.call(instance, p))
|
||||
t.assert.ok(Object.prototype.isPrototypeOf.call(fastify, p))
|
||||
t.assert.ok(p.global)
|
||||
})
|
||||
|
||||
instance.register((i, o, n) => {
|
||||
@@ -127,17 +121,17 @@ test('fastify.register with fastify-plugin should provide access to external fas
|
||||
n()
|
||||
})
|
||||
|
||||
instance.register((i, o, n) => n(), p => t.notOk(p.local))
|
||||
instance.register((i, o, n) => n(), p => t.assert.ok(!p.local))
|
||||
|
||||
instance.register((i, o, n) => {
|
||||
t.ok(i.local)
|
||||
t.assert.ok(i.local)
|
||||
n()
|
||||
}, p => p.decorate('local', () => {}))
|
||||
|
||||
instance.register((i, o, n) => n(), p => t.notOk(p.local))
|
||||
instance.register((i, o, n) => n(), p => t.assert.ok(!p.local))
|
||||
|
||||
instance.register(fp((i, o, n) => {
|
||||
t.ok(i.global_2)
|
||||
t.assert.ok(i.global_2)
|
||||
n()
|
||||
}), p => p.decorate('global_2', () => 'hello'))
|
||||
|
||||
@@ -145,51 +139,46 @@ test('fastify.register with fastify-plugin should provide access to external fas
|
||||
i.decorate('global_2', () => 'world')
|
||||
n()
|
||||
}, p => p.get('/', (req, reply) => {
|
||||
t.ok(p.global_2)
|
||||
t.assert.ok(p.global_2)
|
||||
reply.send({ hello: p.global_2() })
|
||||
}))
|
||||
|
||||
t.notOk(instance.global)
|
||||
t.notOk(instance.global_2)
|
||||
t.notOk(instance.local)
|
||||
t.assert.ok(!instance.global)
|
||||
t.assert.ok(!instance.global_2)
|
||||
t.assert.ok(!instance.local)
|
||||
|
||||
// the decoration is added at the end
|
||||
instance.after(() => {
|
||||
t.ok(instance.global)
|
||||
t.equal(instance.global_2(), 'hello')
|
||||
t.notOk(instance.local)
|
||||
t.assert.ok(instance.global)
|
||||
t.assert.strictEqual(instance.global_2(), 'hello')
|
||||
t.assert.ok(!instance.local)
|
||||
})
|
||||
|
||||
done()
|
||||
})
|
||||
|
||||
fastify.ready(() => {
|
||||
t.notOk(fastify.global)
|
||||
t.assert.ok(!fastify.global)
|
||||
})
|
||||
|
||||
fastify.listen({ port: 0 }, err => {
|
||||
t.error(err)
|
||||
t.teardown(() => { fastify.close() })
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
sget({
|
||||
method: 'GET',
|
||||
url: 'http://localhost:' + fastify.server.address().port
|
||||
}, (err, response, body) => {
|
||||
t.error(err)
|
||||
t.equal(response.statusCode, 200)
|
||||
t.equal(response.headers['content-length'], '' + body.length)
|
||||
t.same(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
})
|
||||
const result = await fetch(fastifyServer)
|
||||
t.assert.ok(result.ok)
|
||||
t.assert.strictEqual(result.status, 200)
|
||||
const body = await result.text()
|
||||
t.assert.strictEqual(result.headers.get('content-length'), '' + body.length)
|
||||
t.assert.deepStrictEqual(JSON.parse(body), { hello: 'world' })
|
||||
})
|
||||
|
||||
test('fastify.register with fastify-plugin registers fastify level plugins', t => {
|
||||
t.plan(15)
|
||||
test('fastify.register with fastify-plugin registers fastify level plugins', async t => {
|
||||
t.plan(14)
|
||||
const fastify = Fastify()
|
||||
|
||||
function fastifyPlugin (instance, opts, done) {
|
||||
instance.decorate('test', 'first')
|
||||
t.ok(instance.test)
|
||||
t.assert.ok(instance.test)
|
||||
done()
|
||||
}
|
||||
|
||||
@@ -201,11 +190,11 @@ test('fastify.register with fastify-plugin registers fastify level plugins', t =
|
||||
fastify.register(fp(fastifyPlugin))
|
||||
|
||||
fastify.register((instance, opts, done) => {
|
||||
t.ok(instance.test)
|
||||
t.assert.ok(instance.test)
|
||||
instance.register(fp(innerPlugin))
|
||||
|
||||
instance.get('/test2', (req, reply) => {
|
||||
t.ok(instance.test2)
|
||||
t.assert.ok(instance.test2)
|
||||
reply.send({ test2: instance.test2 })
|
||||
})
|
||||
|
||||
@@ -213,37 +202,29 @@ test('fastify.register with fastify-plugin registers fastify level plugins', t =
|
||||
})
|
||||
|
||||
fastify.ready(() => {
|
||||
t.ok(fastify.test)
|
||||
t.notOk(fastify.test2)
|
||||
t.assert.ok(fastify.test)
|
||||
t.assert.ok(!fastify.test2)
|
||||
})
|
||||
|
||||
fastify.get('/', (req, reply) => {
|
||||
t.ok(fastify.test)
|
||||
t.assert.ok(fastify.test)
|
||||
reply.send({ test: fastify.test })
|
||||
})
|
||||
|
||||
fastify.listen({ port: 0 }, err => {
|
||||
t.error(err)
|
||||
t.teardown(() => { fastify.close() })
|
||||
const fastifyServer = await fastify.listen({ port: 0 })
|
||||
t.after(() => { fastify.close() })
|
||||
|
||||
sget({
|
||||
method: 'GET',
|
||||
url: 'http://localhost:' + fastify.server.address().port
|
||||
}, (err, response, body) => {
|
||||
t.error(err)
|
||||
t.equal(response.statusCode, 200)
|
||||
t.equal(response.headers['content-length'], '' + body.length)
|
||||
t.same(JSON.parse(body), { test: 'first' })
|
||||
})
|
||||
const result1 = await fetch(fastifyServer)
|
||||
t.assert.ok(result1.ok)
|
||||
t.assert.strictEqual(result1.status, 200)
|
||||
const body1 = await result1.text()
|
||||
t.assert.strictEqual(result1.headers.get('content-length'), '' + body1.length)
|
||||
t.assert.deepStrictEqual(JSON.parse(body1), { test: 'first' })
|
||||
|
||||
sget({
|
||||
method: 'GET',
|
||||
url: 'http://localhost:' + fastify.server.address().port + '/test2'
|
||||
}, (err, response, body) => {
|
||||
t.error(err)
|
||||
t.equal(response.statusCode, 200)
|
||||
t.equal(response.headers['content-length'], '' + body.length)
|
||||
t.same(JSON.parse(body), { test2: 'second' })
|
||||
})
|
||||
})
|
||||
const result2 = await fetch(fastifyServer + '/test2')
|
||||
t.assert.ok(result2.ok)
|
||||
t.assert.strictEqual(result2.status, 200)
|
||||
const body2 = await result2.text()
|
||||
t.assert.strictEqual(result2.headers.get('content-length'), '' + body2.length)
|
||||
t.assert.deepStrictEqual(JSON.parse(body2), { test2: 'second' })
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user