c11836126b
Use `set -u` and `set -o pipefail` to catch accidental mistakes and failures more strongly. - `set -u` catches the use of undefined variables - `set -o pipefail` catches failures (like `set -e`) earlier in the pipeline. This makes the tests a bit more robust. It is nice to read code not worrying about these spurious success paths (via uncaught) errors undermining the tests. Indeed, I caught some bugs doing this. There are a few tests where we run a command that should fail, and then search its output to make sure the failure message is one that we expect. Before, since the `grep` was the last command in the pipeline the exit code of those failing programs was silently ignored. Now with `set -o pipefail` it won't be, and we have to do something so the expected failure doesn't accidentally fail the test. To do that we use `expect` and a new `expectStderr` to check for the exact failing exit code. See the comments on each for why. `grep -q` is replaced with `grepQuiet`, see the comments on that function for why. `grep -v` when we just want the exit code is replaced with `grepInverse, see the comments on that function for why. `grep -q -v` together is, surprise surprise, replaced with `grepQuietInverse`, which is both combined. Co-authored-by: Robert Hensing <roberth@users.noreply.github.com>
97 lines
2 KiB
Bash
Executable file
97 lines
2 KiB
Bash
Executable file
#!/bin/sh
|
|
|
|
set -eux
|
|
|
|
cleanup() {
|
|
PLIST="/Library/LaunchDaemons/org.nixos.nix-daemon.plist"
|
|
if sudo launchctl list | grepQuiet nix-daemon; then
|
|
sudo launchctl unload "$PLIST"
|
|
fi
|
|
|
|
if [ -f "$PLIST" ]; then
|
|
sudo rm /Library/LaunchDaemons/org.nixos.nix-daemon.plist
|
|
fi
|
|
|
|
profiles=(/etc/profile /etc/bashrc /etc/zshrc)
|
|
for profile in "${profiles[@]}"; do
|
|
if [ -f "${profile}.backup-before-nix" ]; then
|
|
sudo mv "${profile}.backup-before-nix" "${profile}"
|
|
fi
|
|
done
|
|
|
|
for file in ~/.bash_profile ~/.bash_login ~/.profile ~/.zshenv ~/.zprofile ~/.zshrc ~/.zlogin; do
|
|
if [ -e "$file" ]; then
|
|
cat "$file" | grep -v nix-profile > "$file.next"
|
|
mv "$file.next" "$file"
|
|
fi
|
|
done
|
|
|
|
for i in $(seq 1 $(sysctl -n hw.ncpu)); do
|
|
sudo /usr/bin/dscl . -delete "/Users/nixbld$i" || true
|
|
done
|
|
sudo /usr/bin/dscl . -delete "/Groups/nixbld" || true
|
|
|
|
sudo rm -rf /etc/nix \
|
|
/nix \
|
|
/var/root/.nix-profile /var/root/.nix-defexpr /var/root/.nix-channels \
|
|
"$HOME/.nix-profile" "$HOME/.nix-defexpr" "$HOME/.nix-channels"
|
|
}
|
|
|
|
verify() {
|
|
set +e
|
|
output=$(echo "nix-shell -p bash --run 'echo toow | rev'" | bash -l)
|
|
set -e
|
|
|
|
test "$output" = "woot"
|
|
}
|
|
|
|
scratch=$(mktemp -d -t tmp.XXXXXXXXXX)
|
|
function finish {
|
|
rm -rf "$scratch"
|
|
}
|
|
trap finish EXIT
|
|
|
|
# First setup Nix
|
|
cleanup
|
|
curl -L -o install https://nixos.org/nix/install
|
|
yes | bash ./install
|
|
verify
|
|
|
|
|
|
(
|
|
set +e
|
|
(
|
|
echo "cd $(pwd)"
|
|
echo nix-build ./release.nix -A binaryTarball.x86_64-darwin
|
|
) | bash -l
|
|
set -e
|
|
cp ./result/nix-*.tar.bz2 $scratch/nix.tar.bz2
|
|
)
|
|
|
|
(
|
|
cd $scratch
|
|
tar -xf ./nix.tar.bz2
|
|
|
|
cd nix-*
|
|
|
|
set -eux
|
|
|
|
cleanup
|
|
|
|
yes | ./install
|
|
verify
|
|
cleanup
|
|
|
|
echo -n "" | ./install
|
|
verify
|
|
cleanup
|
|
|
|
sudo mkdir -p /nix/store
|
|
sudo touch /nix/store/.silly-hint
|
|
echo -n "" | ALLOW_PREEXISTING_INSTALLATION=true ./install
|
|
verify
|
|
test -e /nix/store/.silly-hint
|
|
|
|
cleanup
|
|
)
|