970f492235
This copies the integration tests from `.travis.yaml` into a script, documents the assumptions it makes, and wires it into GitHub Actions. Contrary to the travis version, we don't use Nixery's GCS backend, as handing out access to the bucket used, especially for PRs, needs to be done carefully. Adding back GCS to the integration test can be done at a later point, either by using a mock server, or by only exposing the credentials for master builds (and have the test script decide on whether GOOGLE_APPLICATION_CREDENTIALS is set or not). The previous travis version had some complicated post-mortem log gathering - instead of doing this, we can just `docker run` nixery, but fork it into the background with the shell - causing it to still be able to log its output as it's running. An additional `--rm` is appended, so the container gets cleaned up on termination - this allows subsequent runs on non-CI infrastructure (like developer laptops), without having to manually clean up containers. Fixes #119.
30 lines
876 B
YAML
30 lines
876 B
YAML
# Build Nixery, spin up an instance and pull an image from it.
|
|
name: "Build and test Nixery"
|
|
on:
|
|
push:
|
|
branches:
|
|
- master
|
|
pull_request: {}
|
|
env:
|
|
NIX_PATH: "nixpkgs=https://github.com/NixOS/nixpkgs-channels/archive/0a40a3999eb4d577418515da842a2622a64880c5.tar.gz"
|
|
jobs:
|
|
build-and-test:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: "Do we have Docker?"
|
|
run: |
|
|
docker ps -a
|
|
- name: Install Nix
|
|
uses: cachix/install-nix-action@v13
|
|
- name: Checkout
|
|
uses: actions/checkout@v2.3.4
|
|
- name: Prepare environment
|
|
run: |
|
|
mkdir test-storage
|
|
nix-env -f '<nixpkgs>' -iA go
|
|
- name: Check formatting
|
|
run: "test -z $(gofmt -l .)"
|
|
- name: Build Nixery
|
|
run: "nix-build --arg maxLayers 2"
|
|
- name: Run integration test
|
|
run: scripts/integration-test.sh
|