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 * as cp from 'node:child_process'
import { spawn } from 'node:child_process'
import { mkdir, writeFile, chmod } from 'fs/promises'
import fs from 'fs'
import { join } from 'path'
export const tests = []
const fetch = _fetch // to redefine the real fetch
@ -32,108 +34,161 @@ export const setup = async ({}) => {
return { status, body, headers }
}
return { tmpPath: dir, createFilesIn, sendRequest }
}
// Test the server is running and writes the port in stdout
tests.push(async ({ path, ctx }) => {
ctx.server = cp.spawn('node', [`${path}`])
const startServer = async path => {
const server = spawn('node', [`${path}`])
const message = await Promise.race([
once(ctx.server.stdout, 'data'),
once(server.stdout, 'data'),
Promise.race([
once(ctx.server.stderr, 'data').then(String).then(Error),
once(ctx.server, 'error'),
]).then(x => Promise.reject(x)),
once(server.stderr, 'data').then(String).then(Error),
once(server, 'error'),
]).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)
})
}
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',
headers: {
authorization:
'Basic ' +
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',
headers: {
authorization:
'Basic ' +
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',
headers: {
authorization:
'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
tests.push(async ({ eq, ctx }) => {
const testUnauthorizedRequests = async ({ path, 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',
})
if (status != 401) {
return false
isTestOk = false
}
}
{
const { status, body, headers } = await ctx.sendRequest(``, {
const { status } = await ctx.sendRequest(``, {
method: 'POST',
})
if (status != 401) {
return false
isTestOk = false
}
}
{
const { status, body, headers } = await ctx.sendRequest(
const { status } = await ctx.sendRequest(
`/Rahima_Young:wrongpass`,
{
method: 'POST',
},
)
if (status != 401) {
return false
isTestOk = false
}
}
{
const { status, body, headers } = await ctx.sendRequest(
const { status } = await ctx.sendRequest(
`/Anonymus:abracadabra`,
{
method: 'POST',
},
)
if (status != 401) {
return false
isTestOk = false
}
}
return true
})
server.kill()
return isTestOk
}
tests.push(isServerRunningWell, testGoodRequests, testUnauthorizedRequests)
Object.freeze(tests)

Loading…
Cancel
Save