diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index cc6ecbc..f3d3e3f 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -6,7 +6,7 @@ jobs: tests: strategy: matrix: - os: [ubuntu-18.04, macos] + os: [ubuntu-18.04, macos-latest] runs-on: ${{ matrix.os }} steps: - uses: actions/checkout@v1 @@ -17,4 +17,4 @@ jobs: - run: yarn test - name: Install Nix uses: ./ - - run: nix-build test.nix \ No newline at end of file + - run: nix-build test.nix diff --git a/lib/main.js b/lib/main.js index 97ae998..c79b8f9 100644 --- a/lib/main.js +++ b/lib/main.js @@ -27,12 +27,20 @@ function run() { const home = os_1.homedir(); const { username } = os_1.userInfo(); const PATH = process.env.PATH; + const INSTALL_PATH = '/opt/nix'; const CERTS_PATH = home + '/.nix-profile/etc/ssl/certs/ca-bundle.crt'; // Workaround a segfault: https://github.com/NixOS/nix/issues/2733 yield exec.exec("sudo", ["mkdir", "-p", "/etc/nix"]); yield exec.exec("sudo", ["sh", "-c", "echo http2 = false >> /etc/nix/nix.conf"]); // Set jobs to number of cores yield exec.exec("sudo", ["sh", "-c", "echo max-jobs = auto >> /etc/nix/nix.conf"]); + // Catalina workaround https://github.com/NixOS/nix/issues/2925 + if (os_1.type() == "Darwin") { + yield exec.exec("sudo", ["sh", "-c", `echo \"nix\t${INSTALL_PATH}\" >> /etc/synthetic.conf`]); + yield exec.exec("sudo", ["sh", "-c", `mkdir -m 0755 ${INSTALL_PATH} && chown runner ${INSTALL_PATH}`]); + yield exec.exec("/System/Library/Filesystems/apfs.fs/Contents/Resources/apfs.util", ["-B"]); + core.exportVariable('NIX_IGNORE_SYMLINK_STORE', "1"); + } // TODO: retry due to all the things that go wrong const nixInstall = yield tc.downloadTool('https://nixos.org/nix/install'); yield exec.exec("sh", [nixInstall]); diff --git a/shell.nix b/shell.nix new file mode 100644 index 0000000..07f0cae --- /dev/null +++ b/shell.nix @@ -0,0 +1,8 @@ +{ pkgs ? import {} +}: + +pkgs.mkShell { + name = "install-nix-action-shell"; + + buildInputs = [ pkgs.yarn ]; +} diff --git a/src/main.ts b/src/main.ts index 2ed508a..039c72f 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,7 +1,7 @@ import * as core from '@actions/core'; import * as exec from '@actions/exec'; import * as tc from '@actions/tool-cache'; -import {homedir, userInfo} from 'os'; +import {homedir, userInfo, type} from 'os'; import {existsSync} from 'fs'; async function run() { @@ -9,6 +9,7 @@ async function run() { const home = homedir(); const {username} = userInfo(); const PATH = process.env.PATH; + const INSTALL_PATH = '/opt/nix'; const CERTS_PATH = home + '/.nix-profile/etc/ssl/certs/ca-bundle.crt'; // Workaround a segfault: https://github.com/NixOS/nix/issues/2733 @@ -18,6 +19,14 @@ async function run() { // Set jobs to number of cores await exec.exec("sudo", ["sh", "-c", "echo max-jobs = auto >> /etc/nix/nix.conf"]); + // Catalina workaround https://github.com/NixOS/nix/issues/2925 + if (type() == "Darwin") { + await exec.exec("sudo", ["sh", "-c", `echo \"nix\t${INSTALL_PATH}\" >> /etc/synthetic.conf`]); + await exec.exec("sudo", ["sh", "-c", `mkdir -m 0755 ${INSTALL_PATH} && chown runner ${INSTALL_PATH}`]); + await exec.exec("/System/Library/Filesystems/apfs.fs/Contents/Resources/apfs.util", ["-B"]); + core.exportVariable('NIX_IGNORE_SYMLINK_STORE', "1"); + } + // TODO: retry due to all the things that go wrong const nixInstall = await tc.downloadTool('https://nixos.org/nix/install'); await exec.exec("sh", [nixInstall]);