aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRok Garbas <rok@garbas.si>2022-01-22 21:55:18 +0100
committerGitHub <noreply@github.com>2022-01-22 21:55:18 +0100
commitc9a4ddb9c0a7d15c29d904a017d4d5d58492fdfd (patch)
tree852da92b7fbce4f300e31fef086ac37d6bc5be97
parent5f08db69d18ea5b868cbb58993822e7dd0307518 (diff)
parentd463e1176093da1d4541425bc98ecc58e62dcef5 (diff)
Merge pull request #5829 from NixOS/push-docker-image-to-docker-hub
Push docker image to docker hub for each commit on master
-rw-r--r--.github/workflows/ci.yml (renamed from .github/workflows/test.yml)34
-rw-r--r--doc/manual/src/release-notes/rl-next.md6
-rw-r--r--flake.nix4
3 files changed, 40 insertions, 4 deletions
diff --git a/.github/workflows/test.yml b/.github/workflows/ci.yml
index 1b655e27d..77d9f5250 100644
--- a/.github/workflows/test.yml
+++ b/.github/workflows/ci.yml
@@ -1,4 +1,4 @@
-name: "Test"
+name: "CI"
on:
pull_request:
@@ -74,3 +74,35 @@ jobs:
install_url: '${{needs.installer.outputs.installerURL}}'
install_options: "--tarball-url-prefix https://${{ env.CACHIX_NAME }}.cachix.org/serve"
- run: nix-instantiate -E 'builtins.currentTime' --eval
+
+ docker_push_image:
+ needs: [check_cachix, tests]
+ if: >-
+ github.event_name == 'push' &&
+ github.ref_name == 'master' &&
+ needs.check_cachix.outputs.secret == 'true'
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v2.4.0
+ with:
+ fetch-depth: 0
+ - uses: cachix/install-nix-action@v16
+ - run: echo CACHIX_NAME="$(echo $GITHUB_REPOSITORY-install-tests | tr "[A-Z]/" "[a-z]-")" >> $GITHUB_ENV
+ - run: echo NIX_VERSION="$(nix-instantiate --eval -E '(import ./default.nix).defaultPackage.${builtins.currentSystem}.version' | tr -d \")" >> $GITHUB_ENV
+ - uses: cachix/cachix-action@v10
+ if: needs.check_cachix.outputs.secret == 'true'
+ with:
+ name: '${{ env.CACHIX_NAME }}'
+ signingKey: '${{ secrets.CACHIX_SIGNING_KEY }}'
+ authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
+ - run: nix-build -A checks.$(nix-instantiate --eval -E 'builtins.currentSystem' --json).dockerImage
+ - run: docker load -i ./result/image.tar.gz
+ - run: docker tag nix:$NIX_VERSION nixos/nix:$NIX_VERSION
+ - run: docker tag nix:$NIX_VERSION nixos/nix:master
+ - name: Login to Docker Hub
+ uses: docker/login-action@v1
+ with:
+ username: ${{ secrets.DOCKERHUB_USERNAME }}
+ password: ${{ secrets.DOCKERHUB_TOKEN }}
+ - run: docker push nixos/nix:$NIX_VERSION
+ - run: docker push nixos/nix:master
diff --git a/doc/manual/src/release-notes/rl-next.md b/doc/manual/src/release-notes/rl-next.md
index f20acbd3f..301683246 100644
--- a/doc/manual/src/release-notes/rl-next.md
+++ b/doc/manual/src/release-notes/rl-next.md
@@ -1,6 +1,8 @@
# Release X.Y (202?-??-??)
-* The Nix cli now searches for a flake.nix up until the root of the current git repository or a filesystem boundary rather than just in the current directory
+* The Nix cli now searches for a `flake.nix` up until the root of the current
+ git repository or a filesystem boundary rather than just in the current
+ directory.
* The TOML parser used by `builtins.fromTOML` has been replaced by [a
more compliant one](https://github.com/ToruNiina/toml11).
* Added `:st`/`:show-trace` commands to nix repl, which are used to
@@ -13,3 +15,5 @@
to override the commit summary used when commiting an updated lockfile.
This may be used in conjunction with the nixConfig attribute in
`flake.nix` to better conform to repository conventions.
+* `docker run -ti nixos/nix:master` will place you in the docker container with
+ the latest version of Nix from the `master` branch.
diff --git a/flake.nix b/flake.nix
index 86601fcd9..9bfa36fdf 100644
--- a/flake.nix
+++ b/flake.nix
@@ -562,9 +562,9 @@
binaryTarball = self.hydraJobs.binaryTarball.${system};
perlBindings = self.hydraJobs.perlBindings.${system};
installTests = self.hydraJobs.installTests.${system};
- } // (if system == "x86_64-linux" then {
+ } // (nixpkgs.lib.optionalAttrs (builtins.elem system linux64BitSystems)) {
dockerImage = self.hydraJobs.dockerImage.${system};
- } else {}));
+ });
packages = forAllSystems (system: {
inherit (nixpkgsFor.${system}) nix;