mirror of
https://github.com/actions/runner-container-hooks.git
synced 2025-12-14 00:26:44 +00:00
* added initial entrypoint script * change workingg directory working with addition to fix prepare-job state output * added prepend path * added run-script-step file generation, removed prepend path from container-step and prepare job * latest changes with testing run script step * fix the mounts real fast * cleanup * fix tests * add kind test * add kind yaml to ignore and run it during ci * fix kind option * remove gitignore * lowercase pwd * checkout first! * ignore test file in build.yaml * fixed wrong working directory and added test to run script step testing for the env * handle env's/escaping better * added single quote escape to env escapes * surounded env value with single quote * added spacing around run-container-step, changed examples to actually echo hello world * refactored tests * make sure to escape properly * set addition mounts for container steps * fixup container action mounts Co-authored-by: Thomas Boop <thboop@github.com> Co-authored-by: Thomas Boop <52323235+thboop@users.noreply.github.com>
122 lines
4.1 KiB
TypeScript
122 lines
4.1 KiB
TypeScript
import * as fs from 'fs'
|
|
import { prepareJob } from '../src/hooks'
|
|
import TestSetup from './test-setup'
|
|
|
|
jest.useRealTimers()
|
|
|
|
let prepareJobDefinition
|
|
|
|
let testSetup: TestSetup
|
|
|
|
describe('prepare job', () => {
|
|
beforeEach(() => {
|
|
testSetup = new TestSetup()
|
|
testSetup.initialize()
|
|
prepareJobDefinition = testSetup.getPrepareJobDefinition()
|
|
})
|
|
|
|
afterEach(() => {
|
|
testSetup.teardown()
|
|
})
|
|
|
|
it('should not throw', async () => {
|
|
const prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output.json'
|
|
)
|
|
await expect(
|
|
prepareJob(prepareJobDefinition.args, prepareJobOutput)
|
|
).resolves.not.toThrow()
|
|
|
|
expect(() => fs.readFileSync(prepareJobOutput, 'utf-8')).not.toThrow()
|
|
})
|
|
|
|
it('should have JSON output written to a file', async () => {
|
|
const prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output.json'
|
|
)
|
|
await prepareJob(prepareJobDefinition.args, prepareJobOutput)
|
|
const prepareJobOutputContent = fs.readFileSync(prepareJobOutput, 'utf-8')
|
|
expect(() => JSON.parse(prepareJobOutputContent)).not.toThrow()
|
|
})
|
|
|
|
it('should have context written to a file', async () => {
|
|
const prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output.json'
|
|
)
|
|
await prepareJob(prepareJobDefinition.args, prepareJobOutput)
|
|
const parsedPrepareJobOutput = JSON.parse(
|
|
fs.readFileSync(prepareJobOutput, 'utf-8')
|
|
)
|
|
expect(parsedPrepareJobOutput.context).toBeDefined()
|
|
})
|
|
|
|
it('should have isAlpine field set correctly', async () => {
|
|
let prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output-alpine.json'
|
|
)
|
|
const prepareJobArgsClone = JSON.parse(
|
|
JSON.stringify(prepareJobDefinition.args)
|
|
)
|
|
prepareJobArgsClone.container.image = 'alpine:latest'
|
|
await prepareJob(prepareJobArgsClone, prepareJobOutput)
|
|
|
|
let parsedPrepareJobOutput = JSON.parse(
|
|
fs.readFileSync(prepareJobOutput, 'utf-8')
|
|
)
|
|
expect(parsedPrepareJobOutput.isAlpine).toBe(true)
|
|
|
|
prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output-ubuntu.json'
|
|
)
|
|
prepareJobArgsClone.container.image = 'ubuntu:latest'
|
|
await prepareJob(prepareJobArgsClone, prepareJobOutput)
|
|
parsedPrepareJobOutput = JSON.parse(
|
|
fs.readFileSync(prepareJobOutput, 'utf-8')
|
|
)
|
|
expect(parsedPrepareJobOutput.isAlpine).toBe(false)
|
|
})
|
|
|
|
it('should have container ids written to file', async () => {
|
|
const prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output.json'
|
|
)
|
|
await prepareJob(prepareJobDefinition.args, prepareJobOutput)
|
|
const prepareJobOutputContent = fs.readFileSync(prepareJobOutput, 'utf-8')
|
|
const parsedPrepareJobOutput = JSON.parse(prepareJobOutputContent)
|
|
|
|
expect(parsedPrepareJobOutput.context.container.id).toBeDefined()
|
|
expect(typeof parsedPrepareJobOutput.context.container.id).toBe('string')
|
|
expect(parsedPrepareJobOutput.context.container.id).toMatch(/^[0-9a-f]+$/)
|
|
})
|
|
|
|
it('should have ports for context written in form [containerPort]:[hostPort]', async () => {
|
|
const prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output.json'
|
|
)
|
|
await prepareJob(prepareJobDefinition.args, prepareJobOutput)
|
|
const prepareJobOutputContent = fs.readFileSync(prepareJobOutput, 'utf-8')
|
|
const parsedPrepareJobOutput = JSON.parse(prepareJobOutputContent)
|
|
|
|
const mainContainerPorts = parsedPrepareJobOutput.context.container.ports
|
|
expect(mainContainerPorts['8080']).toBe('80')
|
|
|
|
const redisService = parsedPrepareJobOutput.context.services.find(
|
|
s => s.image === 'redis'
|
|
)
|
|
|
|
const redisServicePorts = redisService.ports
|
|
expect(redisServicePorts['80']).toBe('8080')
|
|
expect(redisServicePorts['8080']).toBe('8088')
|
|
})
|
|
|
|
it('should run prepare job without job container without exception', async () => {
|
|
prepareJobDefinition.args.container = null
|
|
const prepareJobOutput = testSetup.createOutputFile(
|
|
'prepare-job-output.json'
|
|
)
|
|
await expect(
|
|
prepareJob(prepareJobDefinition.args, prepareJobOutput)
|
|
).resolves.not.toThrow()
|
|
})
|
|
})
|