Files
shields/services/hackage/hackage.tester.js
Paul Melnikow 7a664ca3e8 Run prettier (#1866)
Merging this separately so the commit with the tooling change is readable. This is a follow-on to #1167 which turned prettier on.
2018-08-08 17:57:14 -04:00

55 lines
1.4 KiB
JavaScript

'use strict'
const Joi = require('joi')
const ServiceTester = require('../service-tester')
const { isVPlusDottedVersionAtLeastOne } = require('../test-validators')
const t = new ServiceTester({ id: 'hackage', title: 'Hackage' })
module.exports = t
t.create('hackage version (valid)')
.get('/v/lens.json')
.expectJSONTypes(
Joi.object().keys({
name: 'hackage',
value: isVPlusDottedVersionAtLeastOne,
})
)
t.create('hackage deps (valid)')
.get('-deps/v/lens.json')
.expectJSONTypes(
Joi.object().keys({
name: 'dependencies',
value: Joi.string().regex(/^(up to date|outdated)$/),
})
)
t.create('hackage version (not found)')
.get('/v/not-a-package.json')
.expectJSON({ name: 'hackage', value: 'not found' })
t.create('hackage version (not found)')
.get('-deps/v/not-a-package.json')
.expectJSON({ name: 'dependencies', value: 'not found' })
t.create('hackage version (connection error)')
.get('/v/lens.json')
.networkOff()
.expectJSON({ name: 'hackage', value: 'inaccessible' })
t.create('hackage deps (connection error)')
.get('-deps/v/lens.json')
.networkOff()
.expectJSON({ name: 'dependencies', value: 'inaccessible' })
t.create('hackage version (unexpected response)')
.get('/v/lens.json')
.intercept(nock =>
nock('https://hackage.haskell.org')
.get('/package/lens/lens.cabal')
.reply(200, '')
)
.expectJSON({ name: 'hackage', value: 'invalid' })