Browse Source

feat(gatecrashers): add test names, start/kill server for each test, add test for file created and POST answers

pull/1638/head
Michele Sessa 2 years ago committed by Michele
parent
commit
e3e7058507
  1. 133
      js/tests/gatecrashers_test.mjs

133
js/tests/gatecrashers_test.mjs

@ -1,6 +1,8 @@
import { once } from 'node:events' import { once } from 'node:events'
import * as cp from 'node:child_process' import { spawn } from 'node:child_process'
import { mkdir, writeFile, chmod } from 'fs/promises' import { mkdir, writeFile, chmod } from 'fs/promises'
import fs from 'fs'
import { join } from 'path'
export const tests = [] export const tests = []
const fetch = _fetch // to redefine the real fetch const fetch = _fetch // to redefine the real fetch
@ -32,108 +34,161 @@ export const setup = async ({}) => {
return { status, body, headers } return { status, body, headers }
} }
return { tmpPath: dir, createFilesIn, sendRequest } const startServer = async path => {
} const server = spawn('node', [`${path}`])
// Test the server is running and writes the port in stdout
tests.push(async ({ path, ctx }) => {
ctx.server = cp.spawn('node', [`${path}`])
const message = await Promise.race([ const message = await Promise.race([
once(ctx.server.stdout, 'data'), once(server.stdout, 'data'),
Promise.race([ Promise.race([
once(ctx.server.stderr, 'data').then(String).then(Error), once(server.stderr, 'data').then(String).then(Error),
once(ctx.server, 'error'), once(server, 'error'),
]).then(x => Promise.reject(x)), ]).then(result => Promise.reject(result)),
]) ])
return { server, message }
}
return { tmpPath: dir, createFilesIn, sendRequest, startServer }
}
const isServerRunningWell = async ({ path, ctx }) => {
const { server, message } = await ctx.startServer(path)
server.kill()
return message[0].toString().includes(port) return message[0].toString().includes(port)
}) }
const testGoodRequests = async ({ path, eq, ctx }) => {
let isTestOk = true
const expectedBody = {
answer: 'yes',
drink: 'alcohol',
food: 'bats',
}
const dirName = 'guests'
const dirPath = join(ctx.tmpPath, dirName)
const { server } = await ctx.startServer(path)
tests.push(async ({ eq, ctx }) => {
{ {
const { status, body, headers } = await ctx.sendRequest(`/Rahima_Young`, { const { status, body, headers } = await ctx.sendRequest(`/Ana_Riber`, {
method: 'POST', method: 'POST',
headers: { headers: {
authorization: authorization:
'Basic ' + 'Basic ' +
Buffer.from('Caleb_Squires:abracadabra').toString('base64'), Buffer.from('Caleb_Squires:abracadabra').toString('base64'),
body: JSON.stringify(expectedBody),
}, },
}) })
if (status != 200 || headers['content-type'] != 'application/json') {
return false fs.access(`${dirPath}/Ana_Riber.json`, fs.F_OK, err => {
if (err) {
console.error(err)
isTestOk = false
}
})
if (
status != 200 ||
headers['content-type'] != 'application/json' ||
!eq({ body: body }, { body: expectedBody })
) {
isTestOk = false
} }
} }
{ {
const { status, body, headers } = await ctx.sendRequest(`/Rahima_Young`, { const { status, body, headers } = await ctx.sendRequest(`/Rob_Frie`, {
method: 'POST', method: 'POST',
headers: { headers: {
authorization: authorization:
'Basic ' + 'Basic ' +
Buffer.from('Tyrique_Dalton:abracadabra').toString('base64'), Buffer.from('Tyrique_Dalton:abracadabra').toString('base64'),
body: JSON.stringify(expectedBody),
}, },
}) })
if (status != 200 || headers['content-type'] != 'application/json') {
return false fs.access(`${dirPath}/Rob_Frie.json`, fs.F_OK, err => {
if (err) {
console.error(err)
isTestOk = false
}
})
if (
status != 200 ||
headers['content-type'] != 'application/json' ||
!eq({ body: body }, { body: expectedBody })
) {
isTestOk = false
} }
} }
{ {
const { status, body, headers } = await ctx.sendRequest(`/Rahima_Young`, { const { status, body, headers } = await ctx.sendRequest(`/George_Harl`, {
method: 'POST', method: 'POST',
headers: { headers: {
authorization: authorization:
'Basic ' + Buffer.from('Rahima_Young:abracadabra').toString('base64'), 'Basic ' + Buffer.from('Rahima_Young:abracadabra').toString('base64'),
body: JSON.stringify(expectedBody),
}, },
}) })
if (status != 200 || headers['content-type'] != 'application/json') {
return false fs.access(`${dirPath}/George_Harl.json`, fs.F_OK, err => {
if (err) {
console.error(err)
isTestOk = false
}
})
if (
status != 200 ||
headers['content-type'] != 'application/json' ||
!eq({ body: body }, { body: expectedBody })
) {
isTestOk = false
} }
} }
return true server.kill()
}) return isTestOk
}
// Unauthorized requests const testUnauthorizedRequests = async ({ path, ctx }) => {
tests.push(async ({ eq, ctx }) => { let isTestOk = true
const { server } = await ctx.startServer(path)
{ {
const { status, body, headers } = await ctx.sendRequest(`/Rahima_Young`, { const { status } = await ctx.sendRequest(`/Rahima_Young`, {
method: 'POST', method: 'POST',
}) })
if (status != 401) { if (status != 401) {
return false isTestOk = false
} }
} }
{ {
const { status, body, headers } = await ctx.sendRequest(``, { const { status } = await ctx.sendRequest(``, {
method: 'POST', method: 'POST',
}) })
if (status != 401) { if (status != 401) {
return false isTestOk = false
} }
} }
{ {
const { status, body, headers } = await ctx.sendRequest( const { status } = await ctx.sendRequest(
`/Rahima_Young:wrongpass`, `/Rahima_Young:wrongpass`,
{ {
method: 'POST', method: 'POST',
}, },
) )
if (status != 401) { if (status != 401) {
return false isTestOk = false
} }
} }
{ {
const { status, body, headers } = await ctx.sendRequest( const { status } = await ctx.sendRequest(
`/Anonymus:abracadabra`, `/Anonymus:abracadabra`,
{ {
method: 'POST', method: 'POST',
}, },
) )
if (status != 401) { if (status != 401) {
return false isTestOk = false
} }
} }
return true server.kill()
}) return isTestOk
}
tests.push(isServerRunningWell, testGoodRequests, testUnauthorizedRequests)
Object.freeze(tests) Object.freeze(tests)

Loading…
Cancel
Save