mirror of
https://github.com/nestjs/nest.git
synced 2026-02-21 23:11:44 +00:00
fix(platform-fastify): fix versioning (media type and header)
This commit is contained in:
291
integration/versioning/e2e/header-versioning-fastify.spec.ts
Normal file
291
integration/versioning/e2e/header-versioning-fastify.spec.ts
Normal file
@@ -0,0 +1,291 @@
|
||||
import { INestApplication, VersioningType } from '@nestjs/common';
|
||||
import {
|
||||
FastifyAdapter,
|
||||
NestFastifyApplication,
|
||||
} from '@nestjs/platform-fastify';
|
||||
import { Test } from '@nestjs/testing';
|
||||
import * as request from 'supertest';
|
||||
import { AppModule } from '../src/app.module';
|
||||
|
||||
describe('Versioning (fastify)', () => {
|
||||
let app: INestApplication;
|
||||
|
||||
before(async () => {
|
||||
const moduleRef = await Test.createTestingModule({
|
||||
imports: [AppModule],
|
||||
}).compile();
|
||||
|
||||
app = moduleRef.createNestApplication<NestFastifyApplication>(
|
||||
new FastifyAdapter(),
|
||||
);
|
||||
app.enableVersioning({
|
||||
type: VersioningType.HEADER,
|
||||
header: 'X-API-Version',
|
||||
});
|
||||
await app.init();
|
||||
await app.getHttpAdapter().getInstance().ready();
|
||||
});
|
||||
|
||||
describe('GET /', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
'X-API-Version': '1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Hello World V1!');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
'X-API-Version': '2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Hello World V2!');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
'X-API-Version': '3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
'X-API-Version': '',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /:param', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
'X-API-Version': '1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Parameter V1!');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
'X-API-Version': '2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Parameter V2!');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
'X-API-Version': '3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
'X-API-Version': '',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /multiple', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
'X-API-Version': '1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Multiple Versions 1 or 2');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
'X-API-Version': '2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Multiple Versions 1 or 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
'X-API-Version': '3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
'X-API-Version': '',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/multiple').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /neutral', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.set({
|
||||
'X-API-Version': '1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.set({
|
||||
'X-API-Version': '2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.set({
|
||||
'X-API-Version': '',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /override', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
'X-API-Version': '1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Version 1');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
'X-API-Version': '2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Version 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
'X-API-Version': '3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
'X-API-Version': '',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/override').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /override-partial', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
'X-API-Version': '1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Partial Version 1');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
'X-API-Version': '2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Partial Version 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
'X-API-Version': '3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
'X-API-Version': '',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/override-partial').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
after(async () => {
|
||||
await app.close();
|
||||
});
|
||||
});
|
||||
291
integration/versioning/e2e/media-type-versioning-fastify.spec.ts
Normal file
291
integration/versioning/e2e/media-type-versioning-fastify.spec.ts
Normal file
@@ -0,0 +1,291 @@
|
||||
import { INestApplication, VersioningType } from '@nestjs/common';
|
||||
import {
|
||||
FastifyAdapter,
|
||||
NestFastifyApplication,
|
||||
} from '@nestjs/platform-fastify';
|
||||
import { Test } from '@nestjs/testing';
|
||||
import * as request from 'supertest';
|
||||
import { AppModule } from '../src/app.module';
|
||||
|
||||
describe('Versioning (fastify)', () => {
|
||||
let app: INestApplication;
|
||||
|
||||
before(async () => {
|
||||
const moduleRef = await Test.createTestingModule({
|
||||
imports: [AppModule],
|
||||
}).compile();
|
||||
|
||||
app = moduleRef.createNestApplication<NestFastifyApplication>(
|
||||
new FastifyAdapter(),
|
||||
);
|
||||
app.enableVersioning({
|
||||
type: VersioningType.MEDIA_TYPE,
|
||||
key: 'v=',
|
||||
});
|
||||
await app.init();
|
||||
await app.getHttpAdapter().getInstance().ready();
|
||||
});
|
||||
|
||||
describe('GET /', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
Accept: 'application/json;v=1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Hello World V1!');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
Accept: 'application/json;v=2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Hello World V2!');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
Accept: 'application/json;v=3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/')
|
||||
.set({
|
||||
Accept: 'application/json',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /:param', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
Accept: 'application/json;v=1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Parameter V1!');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
Accept: 'application/json;v=2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Parameter V2!');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
Accept: 'application/json;v=3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/param/hello')
|
||||
.set({
|
||||
Accept: '',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /multiple', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
Accept: 'application/json;v=1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Multiple Versions 1 or 2');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
Accept: 'application/json;v=2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Multiple Versions 1 or 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
Accept: 'application/json;v=3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/multiple')
|
||||
.set({
|
||||
Accept: 'application/json',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/multiple').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /neutral', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.set({
|
||||
Accept: 'application/json;v=1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.set({
|
||||
Accept: 'application/json;v=2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.set({
|
||||
Accept: 'application/json',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /override', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
Accept: 'application/json;v=1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Version 1');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
Accept: 'application/json;v=2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Version 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
Accept: 'application/json;v=3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override')
|
||||
.set({
|
||||
Accept: 'application/json',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/override').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /override-partial', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
Accept: 'application/json;v=1',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Partial Version 1');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
Accept: 'application/json;v=2',
|
||||
})
|
||||
.expect(200)
|
||||
.expect('Override Partial Version 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
Accept: 'application/json;v=3',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/override-partial')
|
||||
.set({
|
||||
Accept: 'application/json',
|
||||
})
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Header', () => {
|
||||
return request(app.getHttpServer()).get('/override-partial').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
after(async () => {
|
||||
await app.close();
|
||||
});
|
||||
});
|
||||
162
integration/versioning/e2e/uri-versioning-fastify.spec.ts
Normal file
162
integration/versioning/e2e/uri-versioning-fastify.spec.ts
Normal file
@@ -0,0 +1,162 @@
|
||||
import { INestApplication, VersioningType } from '@nestjs/common';
|
||||
import {
|
||||
FastifyAdapter,
|
||||
NestFastifyApplication,
|
||||
} from '@nestjs/platform-fastify';
|
||||
import { Test } from '@nestjs/testing';
|
||||
import * as request from 'supertest';
|
||||
import { AppModule } from '../src/app.module';
|
||||
|
||||
describe('Versioning (fastify)', () => {
|
||||
let app: INestApplication;
|
||||
|
||||
before(async () => {
|
||||
const moduleRef = await Test.createTestingModule({
|
||||
imports: [AppModule],
|
||||
}).compile();
|
||||
|
||||
app = moduleRef.createNestApplication<NestFastifyApplication>(
|
||||
new FastifyAdapter(),
|
||||
);
|
||||
app.enableVersioning({
|
||||
type: VersioningType.URI,
|
||||
});
|
||||
await app.init();
|
||||
await app.getHttpAdapter().getInstance().ready();
|
||||
});
|
||||
|
||||
describe('GET /', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v1')
|
||||
.expect(200)
|
||||
.expect('Hello World V1!');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v2')
|
||||
.expect(200)
|
||||
.expect('Hello World V2!');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer()).get('/v3/').expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer()).get('/').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /:param', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v1/param/hello')
|
||||
.expect(200)
|
||||
.expect('Parameter V1!');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v2/param/hello')
|
||||
.expect(200)
|
||||
.expect('Parameter V2!');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer()).get('/v3/param/hello').expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer()).get('/param/hello').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /multiple', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v1/multiple')
|
||||
.expect(200)
|
||||
.expect('Multiple Versions 1 or 2');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v2/multiple')
|
||||
.expect(200)
|
||||
.expect('Multiple Versions 1 or 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer()).get('/v3/multiple').expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer()).get('/multiple').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /neutral', () => {
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/neutral')
|
||||
.expect(200)
|
||||
.expect('Neutral');
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /override', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v1/override')
|
||||
.expect(200)
|
||||
.expect('Override Version 1');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v2/override')
|
||||
.expect(200)
|
||||
.expect('Override Version 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer()).get('/v3/override').expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer()).get('/override').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /override-partial', () => {
|
||||
it('V1', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v1/override-partial')
|
||||
.expect(200)
|
||||
.expect('Override Partial Version 1');
|
||||
});
|
||||
|
||||
it('V2', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v2/override-partial')
|
||||
.expect(200)
|
||||
.expect('Override Partial Version 2');
|
||||
});
|
||||
|
||||
it('V3', () => {
|
||||
return request(app.getHttpServer())
|
||||
.get('/v3/override-partial')
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('No Version', () => {
|
||||
return request(app.getHttpServer()).get('/override-partial').expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
after(async () => {
|
||||
await app.close();
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user