Skip to content

Commit

Permalink
feat(cli): add responses for PingController.ping()
Browse files Browse the repository at this point in the history
  • Loading branch information
raymondfeng committed Sep 24, 2018
1 parent 8d105e4 commit 64392f5
Show file tree
Hide file tree
Showing 3 changed files with 75 additions and 3 deletions.
Original file line number Diff line number Diff line change
@@ -1,14 +1,41 @@
import {Request, RestBindings, get} from '@loopback/rest';
import {inject} from '@loopback/context';

const PING_RESPONSE = {
description: 'Ping Response',
content: {
'application/json': {
schema: {
type: 'object',
properties: {
greeting: {type: 'string'},
date: {type: 'string'},
url: {type: 'string'},
headers: {
type: 'object',
patternProperties: {
'^.*$': {type: 'string'},
},
additionalProperties: false,
},
},
},
},
},
};

/**
* A simple controller to bounce back http requests
*/
export class PingController {
constructor(@inject(RestBindings.Http.REQUEST) private req: Request) {}

// Map to `GET /ping`
@get('/ping')
@get('/ping', {
responses: {
'200': PING_RESPONSE,
},
})
ping(): object {
return {
greeting: 'Hello from LoopBack',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import {
Client,
createRestAppClient,
givenHttpServerConfig,
expect,
} from '@loopback/testlab';
import {<%= project.applicationName %>} from '../..';

Expand All @@ -25,7 +26,47 @@ describe('PingController', () => {
});

it('invokes GET /ping', async () => {
await client.get('/ping?msg=world').expect(200);
const res = await client.get('/ping?msg=world').expect(200);
expect(res.body).to.containEql({greeting: 'Hello from LoopBack'});
});

it('exposes OpenAPI spec at /openapi.json', async () => {
const res = await client.get('/openapi.json').expect(200);
expect(res.body).to.containDeep({
paths: {
'/ping': {
get: {
'x-controller-name': 'PingController',
'x-operation-name': 'ping',
tags: ['PingController'],
responses: {
'200': {
description: 'Ping Response',
content: {
'application/json': {
schema: {
type: 'object',
properties: {
greeting: {type: 'string'},
date: {type: 'string'},
url: {type: 'string'},
headers: {
type: 'object',
patternProperties: {
'^.*$': {type: 'string'},
},
additionalProperties: false,
},
},
},
},
},
},
},
},
},
},
});
});

function givenAnApplication() {
Expand Down
6 changes: 5 additions & 1 deletion packages/cli/test/integration/generators/app.integration.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,13 +52,17 @@ describe('app-generator specific files', () => {
assert.fileContent('src/controllers/ping.controller.ts', /@inject/);
assert.fileContent(
'src/controllers/ping.controller.ts',
/@get\('\/ping'\)/,
/@get\('\/ping'\, \{/,
);
assert.fileContent('src/controllers/ping.controller.ts', /ping\(\)/);
assert.fileContent(
'src/controllers/ping.controller.ts',
/\'\@loopback\/rest\'/,
);
assert.fileContent(
'test/acceptance/ping.controller.acceptance.ts',
/describe\('PingController'/,
);
});
});

Expand Down

0 comments on commit 64392f5

Please sign in to comment.