1
0
mirror of https://github.com/badges/shields.git synced 2025-04-18 19:44:04 +03:00
shields/services/dynamic/dynamic-json.tester.js
2024-09-30 09:00:51 +00:00

225 lines
5.9 KiB
JavaScript

import Joi from 'joi'
import { expect } from 'chai'
import { createServiceTester } from '../tester.js'
export const t = await createServiceTester()
t.create('No URL specified')
.get('.json?query=$.name&label=Package Name')
.expectBadge({
label: 'Package Name',
message: 'invalid query parameter: url',
color: 'red',
})
t.create('No query specified')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&label=Package Name',
)
.expectBadge({
label: 'Package Name',
message: 'invalid query parameter: query',
color: 'red',
})
t.create('Malformed url')
.get(
'.json?url=https://github.com/badges/shields/raw/master/%0package.json&query=$.name&label=Package Name',
)
.expectBadge({
label: 'Package Name',
message: 'invalid',
color: 'lightgrey',
})
t.create('JSON from url')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$.name',
)
.expectBadge({
label: 'custom badge',
message: 'shields.io',
color: 'blue',
})
t.create('support uri query parameter')
.get(
'.json?uri=https://github.com/badges/shields/raw/master/package.json&query=$.name',
)
.expectBadge({
label: 'custom badge',
message: 'shields.io',
color: 'blue',
})
t.create('multiple results')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$..keywords[0:2:1]',
)
.expectBadge({ label: 'custom badge', message: 'GitHub, badge' })
t.create('caching with new query params')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$.version',
)
.expectBadge({
label: 'custom badge',
message: Joi.string().regex(/^\d+(\.\d+)?(\.\d+)?$/),
})
t.create('prefix & suffix & label')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$.version&prefix=v&suffix= dev&label=Shields',
)
.expectBadge({
label: 'Shields',
message: Joi.string().regex(/^v\d+(\.\d+)?(\.\d+)?\sdev$/),
})
t.create("key doesn't exist")
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$.does_not_exist',
)
.expectBadge({
label: 'custom badge',
message: 'no result',
color: 'lightgrey',
})
t.create('invalid url')
.get(
'.json?url=https://github.com/badges/shields/raw/master/notafile.json&query=$.version',
)
.expectBadge({
label: 'custom badge',
message: 'resource not found',
color: 'red',
})
t.create('user color overrides default')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$.name&color=10ADED',
)
.expectBadge({
label: 'custom badge',
message: 'shields.io',
color: '#10aded',
})
t.create('error color overrides default')
.get(
'.json?url=https://github.com/badges/shields/raw/master/notafile.json&query=$.version',
)
.expectBadge({
label: 'custom badge',
message: 'resource not found',
color: 'red',
})
t.create('error color overrides user specified')
.get('.json?query=$.version&color=10ADED')
.expectBadge({
label: 'custom badge',
message: 'invalid query parameter: url',
color: 'red',
})
let headers
t.create('request should set Accept header')
.get('.json?url=https://json-test/api.json&query=$.name')
.intercept(nock =>
nock('https://json-test')
.get('/api.json')
.reply(200, function (uri, requestBody) {
headers = this.req.headers
return '{"name":"test"}'
}),
)
.expectBadge({ label: 'custom badge', message: 'test' })
.after(() => {
expect(headers).to.have.property('accept', 'application/json')
})
t.create('query with lexical error')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$[?',
)
.expectBadge({
label: 'custom badge',
message: 'no result',
color: 'lightgrey',
})
t.create('query with parse error')
.get(
'.json?url=https://github.com/badges/shields/raw/master/package.json&query=$.foo,',
)
.expectBadge({
label: 'custom badge',
message: 'no result',
color: 'lightgrey',
})
// Example from https://stackoverflow.com/q/11670384/893113
const invalidTokenQuery =
"$[?(en|**|(@.object.property.one=='other') && (@.object.property.two=='something(abc/def)'))]"
t.create('query with invalid token')
.get(
`.json?url=https://github.com/badges/shields/raw/master/package.json&query=${encodeURIComponent(
invalidTokenQuery,
)}`,
)
.expectBadge({
label: 'custom badge',
message: 'query not supported',
color: 'red',
})
const invalidEscapequery = "$.definitions.common.properties.['@id'].format"
t.create('query with invalid escape')
.get(
`.json?url=https://raw.githubusercontent.com/json-ld/json-ld.org/refs/heads/main/schemas/jsonld-schema.json&query=${encodeURIComponent(
invalidEscapequery,
)}`,
)
.expectBadge({
label: 'custom badge',
message: 'query not supported',
color: 'red',
})
/*
Based on https://github.com/JSONPath-Plus/JSONPath/blob/v9.0.0/test/test.errors.js#L53-L68
This functionality is disabled for security reasons.
*/
t.create('query with eval filtering expression')
.get(
`.json?url=https://github.com/badges/shields/raw/master/package.json&query=${encodeURIComponent(
'$..keywords[(@.length-1)]',
)}`,
)
.expectBadge({
label: 'custom badge',
message: 'query not supported',
color: 'red',
})
t.create('JSON contains an array')
.get('.json?url=https://example.test/json&query=$[0]')
.intercept(nock =>
nock('https://example.test').get('/json').reply(200, '["foo"]'),
)
.expectBadge({
label: 'custom badge',
message: 'foo',
})
t.create('JSON contains a string')
.get('.json?url=https://example.test/json&query=$')
.intercept(nock =>
nock('https://example.test').get('/json').reply(200, '"foo"'),
)
.expectBadge({
label: 'custom badge',
message: 'foo',
})