Projektstart
This commit is contained in:
899
backend/node_modules/@fastify/swagger/test/spec/openapi/route.test.js
generated
vendored
Normal file
899
backend/node_modules/@fastify/swagger/test/spec/openapi/route.test.js
generated
vendored
Normal file
@@ -0,0 +1,899 @@
|
||||
'use strict'
|
||||
|
||||
const { test } = require('node:test')
|
||||
const Fastify = require('fastify')
|
||||
const Swagger = require('@apidevtools/swagger-parser')
|
||||
const yaml = require('yaml')
|
||||
const fastifySwagger = require('../../../index')
|
||||
const {
|
||||
openapiOption,
|
||||
openapiRelativeOptions,
|
||||
schemaBody,
|
||||
schemaConsumes,
|
||||
schemaCookies,
|
||||
schemaExtension,
|
||||
schemaHeaders,
|
||||
schemaHeadersParams,
|
||||
schemaParams,
|
||||
schemaProduces,
|
||||
schemaQuerystring,
|
||||
schemaSecurity,
|
||||
schemaOperationId
|
||||
} = require('../../../examples/options')
|
||||
|
||||
test('openapi should return a valid swagger object', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/', () => {})
|
||||
fastify.post('/', () => {})
|
||||
fastify.get('/example', schemaQuerystring, () => {})
|
||||
fastify.post('/example', schemaBody, () => {})
|
||||
fastify.get('/parameters/:id', schemaParams, () => {})
|
||||
fastify.get('/headers', schemaHeaders, () => {})
|
||||
fastify.get('/headers/:id', schemaHeadersParams, () => {})
|
||||
fastify.get('/security', schemaSecurity, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
})
|
||||
|
||||
test('openapi should return a valid swagger yaml', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/', () => {})
|
||||
fastify.post('/', () => {})
|
||||
fastify.get('/example', schemaQuerystring, () => {})
|
||||
fastify.post('/example', schemaBody, () => {})
|
||||
fastify.get('/parameters/:id', schemaParams, () => {})
|
||||
fastify.get('/headers', schemaHeaders, () => {})
|
||||
fastify.get('/headers/:id', schemaHeadersParams, () => {})
|
||||
fastify.get('/security', schemaSecurity, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const swaggerYaml = fastify.swagger({ yaml: true })
|
||||
t.assert.strictEqual(typeof swaggerYaml, 'string')
|
||||
yaml.parse(swaggerYaml)
|
||||
t.assert.ok(true, 'valid swagger yaml')
|
||||
})
|
||||
|
||||
test('route options - deprecated', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
const opts = {
|
||||
schema: {
|
||||
deprecated: true,
|
||||
body: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
hello: { type: 'string' },
|
||||
obj: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
some: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fastify.post('/', opts, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
|
||||
await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
t.assert.ok(openapiObject.paths['/'])
|
||||
})
|
||||
|
||||
test('route options - meta', async (t) => {
|
||||
t.plan(7)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
const opts = {
|
||||
schema: {
|
||||
operationId: 'doSomething',
|
||||
summary: 'Route summary',
|
||||
tags: ['tag'],
|
||||
description: 'Route description',
|
||||
servers: [
|
||||
{
|
||||
url: 'https://localhost'
|
||||
}
|
||||
],
|
||||
externalDocs: {
|
||||
description: 'Find more info here',
|
||||
url: 'https://swagger.io'
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fastify.get('/', opts, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
const definedPath = api.paths['/'].get
|
||||
t.assert.ok(definedPath)
|
||||
t.assert.strictEqual(opts.schema.operationId, definedPath.operationId)
|
||||
t.assert.strictEqual(opts.schema.summary, definedPath.summary)
|
||||
t.assert.deepEqual(opts.schema.tags, definedPath.tags)
|
||||
t.assert.strictEqual(opts.schema.description, definedPath.description)
|
||||
t.assert.strictEqual(opts.schema.servers, definedPath.servers)
|
||||
t.assert.strictEqual(opts.schema.externalDocs, definedPath.externalDocs)
|
||||
})
|
||||
|
||||
test('route options - produces', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/', schemaProduces, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
const definedPath = api.paths['/'].get
|
||||
t.assert.ok(definedPath)
|
||||
t.assert.deepEqual(definedPath.responses[200].content, {
|
||||
'*/*': {
|
||||
schema: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
hello: {
|
||||
description: 'hello',
|
||||
type: 'string'
|
||||
}
|
||||
},
|
||||
required: ['hello']
|
||||
}
|
||||
}
|
||||
|
||||
})
|
||||
})
|
||||
|
||||
test('route options - cookies', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/', schemaCookies, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
const definedPath = api.paths['/'].get
|
||||
t.assert.ok(definedPath)
|
||||
t.assert.deepEqual(definedPath.parameters, [
|
||||
{
|
||||
required: false,
|
||||
in: 'cookie',
|
||||
name: 'bar',
|
||||
schema: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
test('route options - extension', async (t) => {
|
||||
t.plan(4)
|
||||
const fastify = Fastify()
|
||||
await fastify.register(fastifySwagger, { openapi: { 'x-ternal': true } })
|
||||
fastify.get('/', schemaExtension, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
t.assert.ok(api['x-ternal'])
|
||||
t.assert.deepEqual(api['x-ternal'], true)
|
||||
|
||||
const definedPath = api.paths['/'].get
|
||||
t.assert.ok(definedPath)
|
||||
t.assert.deepEqual(definedPath['x-tension'], true)
|
||||
})
|
||||
|
||||
test('parses form parameters when all api consumes application/x-www-form-urlencoded', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
fastify.post('/', schemaConsumes, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
const definedPath = api.paths['/'].post
|
||||
t.assert.ok(definedPath)
|
||||
t.assert.deepEqual(definedPath.requestBody.content, {
|
||||
'application/x-www-form-urlencoded': {
|
||||
schema: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
hello: {
|
||||
description: 'hello',
|
||||
type: 'string'
|
||||
}
|
||||
},
|
||||
required: ['hello']
|
||||
}
|
||||
}
|
||||
|
||||
})
|
||||
})
|
||||
|
||||
test('route options - method', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.route({
|
||||
method: ['GET', 'POST'],
|
||||
url: '/',
|
||||
handler: function (request, reply) {
|
||||
reply.send({ hello: 'world' })
|
||||
}
|
||||
})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
})
|
||||
|
||||
test('cookie, query, path description', async (t) => {
|
||||
t.plan(6)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
const schemaCookies = {
|
||||
schema: {
|
||||
cookies: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
bar: { type: 'string', description: 'Bar' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
const schemaQuerystring = {
|
||||
schema: {
|
||||
querystring: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
hello: { type: 'string', description: 'Hello' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
// test without description as other test case for params already have description
|
||||
const schemaParams = {
|
||||
schema: {
|
||||
params: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
id: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fastify.get('/', schemaCookies, () => {})
|
||||
fastify.get('/example', schemaQuerystring, () => {})
|
||||
fastify.get('/parameters/:id', schemaParams, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
const cookiesPath = api.paths['/'].get
|
||||
t.assert.ok(cookiesPath)
|
||||
t.assert.deepEqual(cookiesPath.parameters, [
|
||||
{
|
||||
required: false,
|
||||
in: 'cookie',
|
||||
name: 'bar',
|
||||
description: 'Bar',
|
||||
schema: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
])
|
||||
const querystringPath = api.paths['/example'].get
|
||||
t.assert.ok(querystringPath)
|
||||
t.assert.deepEqual(querystringPath.parameters, [
|
||||
{
|
||||
required: false,
|
||||
in: 'query',
|
||||
name: 'hello',
|
||||
description: 'Hello',
|
||||
schema: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
])
|
||||
const paramPath = api.paths['/parameters/{id}'].get
|
||||
t.assert.ok(paramPath)
|
||||
t.assert.deepEqual(paramPath.parameters, [
|
||||
{
|
||||
required: true,
|
||||
in: 'path',
|
||||
name: 'id',
|
||||
schema: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
test('cookie and query with serialization type', async (t) => {
|
||||
t.plan(4)
|
||||
const fastify = Fastify({
|
||||
ajv: {
|
||||
plugins: [
|
||||
function (ajv) {
|
||||
ajv.addKeyword({
|
||||
keyword: 'x-consume'
|
||||
})
|
||||
}
|
||||
]
|
||||
}
|
||||
})
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
const schemaCookies = {
|
||||
schema: {
|
||||
cookies: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
bar: {
|
||||
type: 'object',
|
||||
'x-consume': 'application/json',
|
||||
required: ['foo'],
|
||||
properties: {
|
||||
foo: { type: 'string' },
|
||||
bar: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
const schemaQuerystring = {
|
||||
schema: {
|
||||
querystring: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
hello: {
|
||||
type: 'object',
|
||||
'x-consume': 'application/json',
|
||||
required: ['bar'],
|
||||
properties: {
|
||||
bar: { type: 'string' },
|
||||
baz: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fastify.get('/', schemaCookies, () => {})
|
||||
fastify.get('/example', schemaQuerystring, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
|
||||
const cookiesPath = api.paths['/'].get
|
||||
t.assert.ok(cookiesPath)
|
||||
t.assert.deepEqual(cookiesPath.parameters, [
|
||||
{
|
||||
[Symbol.for('@fastify/swagger.rawRequired')]: ['foo'],
|
||||
required: false,
|
||||
in: 'cookie',
|
||||
name: 'bar',
|
||||
content: {
|
||||
'application/json': {
|
||||
schema: {
|
||||
type: 'object',
|
||||
required: ['foo'],
|
||||
properties: {
|
||||
foo: { type: 'string' },
|
||||
bar: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
])
|
||||
|
||||
const querystringPath = api.paths['/example'].get
|
||||
t.assert.ok(querystringPath)
|
||||
t.assert.deepEqual(querystringPath.parameters, [
|
||||
{
|
||||
required: false,
|
||||
in: 'query',
|
||||
name: 'hello',
|
||||
content: {
|
||||
'application/json': {
|
||||
schema: {
|
||||
type: 'object',
|
||||
required: ['bar'],
|
||||
properties: {
|
||||
bar: { type: 'string' },
|
||||
baz: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
test('openapi should pass through operationId', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/hello', schemaOperationId, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
})
|
||||
|
||||
test('openapi should pass through Links', async (t) => {
|
||||
t.plan(3)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/user/:id', {
|
||||
schema: {
|
||||
params: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'the user identifier, as userId'
|
||||
}
|
||||
},
|
||||
required: ['id']
|
||||
},
|
||||
response: {
|
||||
200: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
uuid: {
|
||||
type: 'string',
|
||||
format: 'uuid'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
links: {
|
||||
200: {
|
||||
address: {
|
||||
operationId: 'getUserAddress',
|
||||
parameters: {
|
||||
id: '$request.path.id'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
fastify.get('/user/:id/address', {
|
||||
schema: {
|
||||
operationId: 'getUserAddress',
|
||||
params: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'the user identifier, as userId'
|
||||
}
|
||||
},
|
||||
required: ['id']
|
||||
},
|
||||
response: {
|
||||
200: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
t.assert.deepEqual(api.paths['/user/{id}'].get.responses['200'].links, {
|
||||
address: {
|
||||
operationId: 'getUserAddress',
|
||||
parameters: {
|
||||
id: '$request.path.id'
|
||||
}
|
||||
}
|
||||
|
||||
})
|
||||
})
|
||||
|
||||
test('links without status code', async (t) => {
|
||||
t.plan(1)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/user/:id', {
|
||||
schema: {
|
||||
params: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'the user identifier, as userId'
|
||||
}
|
||||
},
|
||||
required: ['id']
|
||||
},
|
||||
response: {
|
||||
200: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
uuid: {
|
||||
type: 'string',
|
||||
format: 'uuid'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
links: {
|
||||
201: {
|
||||
address: {
|
||||
operationId: 'getUserAddress',
|
||||
parameters: {
|
||||
id: '$request.path.id'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
fastify.get('/user/:id/address', {
|
||||
schema: {
|
||||
operationId: 'getUserAddress',
|
||||
params: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'the user identifier, as userId'
|
||||
}
|
||||
},
|
||||
required: ['id']
|
||||
},
|
||||
response: {
|
||||
200: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
t.assert.throws(() => fastify.swagger(), new Error('missing status code 201 in route /user/:id'))
|
||||
})
|
||||
|
||||
test('security headers ignored when declared in security and securityScheme', async (t) => {
|
||||
t.plan(6)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiOption)
|
||||
|
||||
fastify.get('/address1/:id', {
|
||||
schema: {
|
||||
headers: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
apiKey: {
|
||||
type: 'string',
|
||||
description: 'api token'
|
||||
},
|
||||
bearerAuth: {
|
||||
type: 'string',
|
||||
description: 'authorization bearer'
|
||||
},
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'common field'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
fastify.get('/address2/:id', {
|
||||
schema: {
|
||||
headers: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
authKey: {
|
||||
type: 'string',
|
||||
description: 'auth token'
|
||||
},
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'common field'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
t.assert.ok(api.paths['/address1/{id}'].get.parameters.find(({ name }) => (name === 'id')))
|
||||
t.assert.ok(api.paths['/address2/{id}'].get.parameters.find(({ name }) => (name === 'id')))
|
||||
t.assert.strictEqual(api.paths['/address1/{id}'].get.parameters.find(({ name }) => (name === 'apiKey')), undefined)
|
||||
t.assert.ok(api.paths['/address2/{id}'].get.parameters.find(({ name }) => (name === 'authKey')))
|
||||
})
|
||||
|
||||
test('security querystrings ignored when declared in security and securityScheme', async (t) => {
|
||||
t.plan(6)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, {
|
||||
openapi: {
|
||||
components: {
|
||||
securitySchemes: {
|
||||
apiKey: {
|
||||
type: 'apiKey',
|
||||
name: 'apiKey',
|
||||
in: 'query'
|
||||
}
|
||||
}
|
||||
},
|
||||
security: [{
|
||||
apiKey: []
|
||||
}]
|
||||
}
|
||||
})
|
||||
|
||||
fastify.get('/address1/:id', {
|
||||
schema: {
|
||||
querystring: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
apiKey: {
|
||||
type: 'string',
|
||||
description: 'api token'
|
||||
},
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'common field'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
fastify.get('/address2/:id', {
|
||||
schema: {
|
||||
querystring: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
authKey: {
|
||||
type: 'string',
|
||||
description: 'auth token'
|
||||
},
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'common field'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
t.assert.ok(api.paths['/address1/{id}'].get.parameters.find(({ name }) => (name === 'id')))
|
||||
t.assert.ok(api.paths['/address2/{id}'].get.parameters.find(({ name }) => (name === 'id')))
|
||||
t.assert.strictEqual(api.paths['/address1/{id}'].get.parameters.find(({ name }) => (name === 'apiKey')), undefined)
|
||||
t.assert.ok(api.paths['/address2/{id}'].get.parameters.find(({ name }) => (name === 'authKey')))
|
||||
})
|
||||
|
||||
test('security cookies ignored when declared in security and securityScheme', async (t) => {
|
||||
t.plan(6)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, {
|
||||
openapi: {
|
||||
components: {
|
||||
securitySchemes: {
|
||||
apiKey: {
|
||||
type: 'apiKey',
|
||||
name: 'apiKey',
|
||||
in: 'cookie'
|
||||
}
|
||||
}
|
||||
},
|
||||
security: [{
|
||||
apiKey: []
|
||||
}]
|
||||
}
|
||||
})
|
||||
|
||||
fastify.get('/address1/:id', {
|
||||
schema: {
|
||||
cookies: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
apiKey: {
|
||||
type: 'string',
|
||||
description: 'api token'
|
||||
},
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'common field'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
fastify.get('/address2/:id', {
|
||||
schema: {
|
||||
cookies: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
authKey: {
|
||||
type: 'string',
|
||||
description: 'auth token'
|
||||
},
|
||||
id: {
|
||||
type: 'string',
|
||||
description: 'common field'
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
t.assert.strictEqual(typeof openapiObject, 'object')
|
||||
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
t.assert.ok(true, 'valid swagger object')
|
||||
t.assert.ok(api.paths['/address1/{id}'].get.parameters.find(({ name }) => (name === 'id')))
|
||||
t.assert.ok(api.paths['/address2/{id}'].get.parameters.find(({ name }) => (name === 'id')))
|
||||
t.assert.strictEqual(api.paths['/address1/{id}'].get.parameters.find(({ name }) => (name === 'apiKey')), undefined)
|
||||
t.assert.ok(api.paths['/address2/{id}'].get.parameters.find(({ name }) => (name === 'authKey')))
|
||||
})
|
||||
|
||||
test('path params on relative url', async (t) => {
|
||||
t.plan(2)
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiRelativeOptions)
|
||||
|
||||
const schemaParams = {
|
||||
schema: {
|
||||
params: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
id: { type: 'string' }
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
fastify.get('/parameters/:id', schemaParams, () => {})
|
||||
|
||||
await fastify.ready()
|
||||
|
||||
const openapiObject = fastify.swagger()
|
||||
const api = await Swagger.validate(openapiObject)
|
||||
const paramPath = api.paths['/parameters/{id}'].get
|
||||
t.assert.ok(paramPath)
|
||||
t.assert.deepEqual(paramPath.parameters, [
|
||||
{
|
||||
required: true,
|
||||
in: 'path',
|
||||
name: 'id',
|
||||
schema: {
|
||||
type: 'string'
|
||||
}
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
test('verify generated path param definition with route prefixing', async (t) => {
|
||||
const opts = {
|
||||
schema: {}
|
||||
}
|
||||
|
||||
const fastify = Fastify()
|
||||
|
||||
await fastify.register(fastifySwagger, openapiRelativeOptions)
|
||||
await fastify.register(function (app, _, done) {
|
||||
app.get('/:userId', opts, () => {})
|
||||
|
||||
done()
|
||||
}, { prefix: '/v1' })
|
||||
await fastify.ready()
|
||||
|
||||
const swaggerObject = fastify.swagger()
|
||||
const api = await Swagger.validate(swaggerObject)
|
||||
|
||||
const definedPath = api.paths['/v1/{userId}'].get
|
||||
|
||||
t.assert.deepEqual(definedPath.parameters, [{
|
||||
schema: {
|
||||
type: 'string'
|
||||
},
|
||||
in: 'path',
|
||||
name: 'userId',
|
||||
required: true
|
||||
}])
|
||||
})
|
||||
Reference in New Issue
Block a user