This is a bit of sugar that reduces the boilerplate for creating testers in what I expect will become the standard case: a service in `foo/foo-thing.service.js` with its tests in `foo/foo-thing.tester.js`. This makes a small stylistic change, which is to name the service by its CamelCase class name rather than an invented snake-case ID. Whereas before the name was specified in `class FooThing extends Base[Json]Service` and a second time in the tester, it now only needs to be specified once.
25 lines
523 B
JavaScript
25 lines
523 B
JavaScript
'use strict'
|
|
|
|
const Joi = require('joi')
|
|
const createServiceTester = require('../create-service-tester')
|
|
const { anyInteger } = require('../validators')
|
|
|
|
const t = createServiceTester()
|
|
module.exports = t
|
|
|
|
t.create('sourcerank')
|
|
.get('/npm/got.json')
|
|
.expectJSONTypes(
|
|
Joi.object().keys({
|
|
name: 'sourcerank',
|
|
value: anyInteger,
|
|
})
|
|
)
|
|
|
|
t.create('dependent count (not a package)')
|
|
.get('/npm/foobar-is-not-package.json')
|
|
.expectJSON({
|
|
name: 'sourcerank',
|
|
value: 'package not found',
|
|
})
|