mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
eee8f364de
refs https://github.com/TryGhost/Toolbox/issues/280 - Some additional coverage showcasing the versioning support is universal across APIs
112 lines
4.2 KiB
JavaScript
112 lines
4.2 KiB
JavaScript
const {agentProvider, fixtureManager, matchers} = require('../../utils/e2e-framework');
|
|
const {anyErrorId, anyString, stringMatching} = matchers;
|
|
|
|
describe('API Versioning', function () {
|
|
describe('Admin API', function () {
|
|
let agentAdminAPI;
|
|
|
|
before(async function () {
|
|
agentAdminAPI = await agentProvider.getAdminAPIAgent();
|
|
});
|
|
|
|
it('responds with no content version header when accept version header is NOT PRESENT', async function () {
|
|
await agentAdminAPI
|
|
.get('site/')
|
|
.matchBodySnapshot({
|
|
site: {
|
|
version: stringMatching(/\d+\.\d+/)
|
|
}
|
|
})
|
|
.matchHeaderSnapshot({
|
|
etag: anyString
|
|
});
|
|
});
|
|
|
|
it('responds with current content version header when requested version is BEHIND current version and CAN respond', async function () {
|
|
await agentAdminAPI
|
|
.get('site/')
|
|
.header('Accept-Version', 'v3.0')
|
|
.matchBodySnapshot({
|
|
site: {
|
|
version: stringMatching(/\d+\.\d+/)
|
|
}
|
|
})
|
|
.matchHeaderSnapshot({
|
|
etag: anyString,
|
|
'content-version': stringMatching(/v\d+\.\d+/)
|
|
});
|
|
});
|
|
|
|
it('responds with current content version header when requested version is AHEAD and CAN respond', async function () {
|
|
await agentAdminAPI
|
|
.get('site/')
|
|
.header('Accept-Version', 'v999.5')
|
|
.matchBodySnapshot({
|
|
site: {
|
|
version: stringMatching(/\d+\.\d+/)
|
|
}
|
|
})
|
|
.matchHeaderSnapshot({
|
|
etag: anyString,
|
|
'content-version': stringMatching(/v\d+\.\d+/)
|
|
});
|
|
});
|
|
|
|
it('responds with error current content version header when requested version is AHEAD and CANNOT respond', async function () {
|
|
// CASE 2: If accept-version is behind, send a 406 & tell them the client needs updating.
|
|
await agentAdminAPI
|
|
.get('removed_endpoint')
|
|
.header('Accept-Version', 'v999.1')
|
|
.matchHeaderSnapshot({
|
|
etag: anyString
|
|
})
|
|
.matchBodySnapshot({
|
|
errors: [{
|
|
id: anyErrorId
|
|
}]
|
|
});
|
|
});
|
|
|
|
it('responds with error current content version header when requested version is BEHIND and CANNOT respond', async function () {
|
|
// CASE 2: If accept-version is behind, send a 406 & tell them the client needs updating.
|
|
await agentAdminAPI
|
|
.get('removed_endpoint')
|
|
.header('Accept-Version', 'v3.1')
|
|
.matchHeaderSnapshot({
|
|
etag: anyString
|
|
})
|
|
.matchBodySnapshot({
|
|
errors: [{
|
|
id: anyErrorId
|
|
}]
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('Content API', function () {
|
|
let agentContentAPI;
|
|
|
|
before(async function () {
|
|
agentContentAPI = await agentProvider.getContentAPIAgent();
|
|
await fixtureManager.init('api_keys');
|
|
agentContentAPI.authenticate();
|
|
});
|
|
|
|
it('responds with no content version header when accept version header is NOT PRESENT', async function () {
|
|
await agentContentAPI.get('settings/')
|
|
.expectStatus(200)
|
|
.matchHeaderSnapshot()
|
|
.matchBodySnapshot();
|
|
});
|
|
|
|
it('responds with current content version header when requested version is BEHIND current version and CAN respond', async function () {
|
|
await agentContentAPI.get('settings/')
|
|
.header('Accept-Version', 'v3.0')
|
|
.expectStatus(200)
|
|
.matchHeaderSnapshot({
|
|
'content-version': stringMatching(/v\d+\.\d+/)
|
|
})
|
|
.matchBodySnapshot();
|
|
});
|
|
});
|
|
});
|