diff --git a/__test__/entrypoint.sh b/__test__/entrypoint.sh new file mode 100755 index 0000000..a37ef21 --- /dev/null +++ b/__test__/entrypoint.sh @@ -0,0 +1,29 @@ +#!/bin/sh -l +set -euo pipefail + +# Save the working directory +WORKINGDIR=$PWD + +# Serve remote repo +mkdir /git +git init --bare /git/test-repo.git +git daemon --verbose --enable=receive-pack --base-path=/git --export-all /git/test-repo.git &>/dev/null & + +# Give the daemon time to start +sleep 2 + +# Clone and make an initial commit +git clone git://127.0.0.1/test-repo.git /git/test-repo +cd /git/test-repo +git config --global user.email "you@example.com" +git config --global user.name "Your Name" +echo "#test-repo" > README.md +git add . +git commit -m "initial commit" +git push -u + +# Restore the working directory +cd $WORKINGDIR + +# Execute integration tests +jest int diff --git a/__test__/git.test.ts b/__test__/git.int.test.ts similarity index 89% rename from __test__/git.test.ts rename to __test__/git.int.test.ts index 713ca03..8c3b2a0 100644 --- a/__test__/git.test.ts +++ b/__test__/git.int.test.ts @@ -1,6 +1,4 @@ -import * as path from 'path' import { - ConfigOption, getRepoPath, execGit, addConfigOption, @@ -15,7 +13,7 @@ const originalGitHubWorkspace = process.env['GITHUB_WORKSPACE'] describe('git tests', () => { beforeAll(() => { // GitHub workspace - process.env['GITHUB_WORKSPACE'] = __dirname + process.env['GITHUB_WORKSPACE'] = '/git/test-repo' }) afterAll(() => { @@ -26,14 +24,7 @@ describe('git tests', () => { } }) - test('getRepoPath', async () => { - expect(getRepoPath()).toEqual(process.env['GITHUB_WORKSPACE']) - expect(getRepoPath('foo')).toEqual( - path.resolve(process.env['GITHUB_WORKSPACE'] || '', 'foo') - ) - }) - - test('execGit', async () => { + it('successfully executes a git command', async () => { const repoPath = getRepoPath() const result = await execGit( repoPath, @@ -75,13 +66,13 @@ describe('git tests', () => { expect(unset).toBeTruthy() }) - test('configOptionExists returns true', async () => { + it('determines that a config option exists', async () => { const repoPath = getRepoPath() const result = await configOptionExists(repoPath, 'remote.origin.url') expect(result).toBeTruthy() }) - test('configOptionExists returns false', async () => { + it('determines that a config option does not exist', async () => { const repoPath = getRepoPath() const result = await configOptionExists(repoPath, 'this.key.does.not.exist') expect(result).toBeFalsy() diff --git a/__test__/git.unit.test.ts b/__test__/git.unit.test.ts new file mode 100644 index 0000000..adf0448 --- /dev/null +++ b/__test__/git.unit.test.ts @@ -0,0 +1,26 @@ +import * as path from 'path' +import {getRepoPath} from '../lib/git' + +const originalGitHubWorkspace = process.env['GITHUB_WORKSPACE'] + +describe('git tests', () => { + beforeAll(() => { + // GitHub workspace + process.env['GITHUB_WORKSPACE'] = __dirname + }) + + afterAll(() => { + // Restore GitHub workspace + delete process.env['GITHUB_WORKSPACE'] + if (originalGitHubWorkspace) { + process.env['GITHUB_WORKSPACE'] = originalGitHubWorkspace + } + }) + + test('getRepoPath', async () => { + expect(getRepoPath()).toEqual(process.env['GITHUB_WORKSPACE']) + expect(getRepoPath('foo')).toEqual( + path.resolve(process.env['GITHUB_WORKSPACE'] || '', 'foo') + ) + }) +}) diff --git a/__test__/integration-tests.sh b/__test__/integration-tests.sh new file mode 100755 index 0000000..43f5ae5 --- /dev/null +++ b/__test__/integration-tests.sh @@ -0,0 +1,23 @@ +#!/usr/bin/env bash +set -euo pipefail + +IMAGE="cpr-integration-tests:latest" +ARG1=${1:-} + +if [[ "$(docker images -q $IMAGE 2> /dev/null)" == "" || $ARG1 == "build" ]]; then + echo "Building Docker image $IMAGE ..." + + cat > Dockerfile << EOF +FROM node:12-alpine +RUN apk --no-cache add git git-daemon +RUN npm install jest --global +WORKDIR /cpr +COPY __test__/entrypoint.sh /entrypoint.sh +ENTRYPOINT ["/entrypoint.sh"] +EOF + + docker build -t $IMAGE . + rm Dockerfile +fi + +docker run -v $PWD:/cpr $IMAGE diff --git a/package.json b/package.json index 9a74e1e..b33d4c5 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,9 @@ "format": "prettier --write '**/*.ts'", "format-check": "prettier --check '**/*.ts'", "lint": "eslint src/**/*.ts", - "test": "jest --passWithNoTests", + "test:unit": "jest unit", + "test:int": "__test__/integration-tests.sh", + "test": "npm run test:unit && npm run test:int", "pack-assets": "mkdir -p dist/cpr && cp -rv src/cpr/* dist/cpr", "vendor-deps": "pip download -r src/cpr/requirements.txt --no-binary=:all: -d dist/vendor", "package": "npm run build && npm run pack-assets && npm run vendor-deps"