2024-05-28 16:43:04 +00:00
|
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
2015-06-01 14:18:23 +00:00
|
|
|
|
source common.sh
|
|
|
|
|
|
2024-06-16 15:56:50 +00:00
|
|
|
|
clearStoreIfPossible
|
2015-06-01 14:18:23 +00:00
|
|
|
|
|
2016-05-30 12:53:57 +00:00
|
|
|
|
rm -rf $TEST_HOME
|
2015-06-02 11:20:43 +00:00
|
|
|
|
|
2015-06-01 14:18:23 +00:00
|
|
|
|
tarroot=$TEST_ROOT/tarball
|
|
|
|
|
rm -rf $tarroot
|
|
|
|
|
mkdir -p $tarroot
|
|
|
|
|
cp dependencies.nix $tarroot/default.nix
|
|
|
|
|
cp config.nix dependencies.builder*.sh $tarroot/
|
2023-08-22 17:29:25 +00:00
|
|
|
|
touch -d '@1000000000' $tarroot $tarroot/*
|
2015-06-01 14:18:23 +00:00
|
|
|
|
|
2020-07-24 16:44:43 +00:00
|
|
|
|
hash=$(nix hash path $tarroot)
|
2020-03-30 14:04:18 +00:00
|
|
|
|
|
2019-12-13 16:26:58 +00:00
|
|
|
|
test_tarball() {
|
|
|
|
|
local ext="$1"
|
|
|
|
|
local compressor="$2"
|
2015-06-01 14:18:23 +00:00
|
|
|
|
|
2019-12-13 16:26:58 +00:00
|
|
|
|
tarball=$TEST_ROOT/tarball.tar$ext
|
2023-10-23 21:46:06 +00:00
|
|
|
|
(cd $TEST_ROOT && GNUTAR_REPRODUCIBLE= tar --mtime=$tarroot/default.nix --owner=0 --group=0 --numeric-owner --sort=name -c -f - tarball) | $compressor > $tarball
|
2015-06-01 14:18:23 +00:00
|
|
|
|
|
2021-12-09 15:26:46 +00:00
|
|
|
|
nix-env -f file://$tarball -qa --out-path | grepQuiet dependencies
|
2015-06-01 14:18:23 +00:00
|
|
|
|
|
2019-12-13 16:26:58 +00:00
|
|
|
|
nix-build -o $TEST_ROOT/result file://$tarball
|
2015-06-01 14:18:23 +00:00
|
|
|
|
|
2019-12-13 16:26:58 +00:00
|
|
|
|
nix-build -o $TEST_ROOT/result '<foo>' -I foo=file://$tarball
|
2016-04-14 13:32:24 +00:00
|
|
|
|
|
2019-12-13 16:26:58 +00:00
|
|
|
|
nix-build -o $TEST_ROOT/result -E "import (fetchTarball file://$tarball)"
|
2022-02-27 14:25:22 +00:00
|
|
|
|
# Do not re-fetch paths already present
|
|
|
|
|
nix-build -o $TEST_ROOT/result -E "import (fetchTarball { url = file:///does-not-exist/must-remain-unused/$tarball; sha256 = \"$hash\"; })"
|
2016-04-14 13:32:24 +00:00
|
|
|
|
|
2020-04-29 20:39:58 +00:00
|
|
|
|
nix-build -o $TEST_ROOT/result -E "import (fetchTree file://$tarball)"
|
|
|
|
|
nix-build -o $TEST_ROOT/result -E "import (fetchTree { type = \"tarball\"; url = file://$tarball; })"
|
|
|
|
|
nix-build -o $TEST_ROOT/result -E "import (fetchTree { type = \"tarball\"; url = file://$tarball; narHash = \"$hash\"; })"
|
2022-02-27 14:25:22 +00:00
|
|
|
|
# Do not re-fetch paths already present
|
|
|
|
|
nix-build -o $TEST_ROOT/result -E "import (fetchTree { type = \"tarball\"; url = file:///does-not-exist/must-remain-unused/$tarball; narHash = \"$hash\"; })"
|
2021-12-09 15:26:46 +00:00
|
|
|
|
expectStderr 102 nix-build -o $TEST_ROOT/result -E "import (fetchTree { type = \"tarball\"; url = file://$tarball; narHash = \"sha256-xdKv2pq/IiwLSnBBJXW8hNowI4MrdZfW+SYqDQs7Tzc=\"; })" | grep 'NAR hash mismatch in input'
|
2020-04-29 20:39:58 +00:00
|
|
|
|
|
2023-08-22 17:29:25 +00:00
|
|
|
|
[[ $(nix eval --impure --expr "(fetchTree file://$tarball).lastModified") = 1000000000 ]]
|
|
|
|
|
|
2020-04-29 20:39:58 +00:00
|
|
|
|
nix-instantiate --strict --eval -E "!((import (fetchTree { type = \"tarball\"; url = file://$tarball; narHash = \"$hash\"; })) ? submodules)" >&2
|
|
|
|
|
nix-instantiate --strict --eval -E "!((import (fetchTree { type = \"tarball\"; url = file://$tarball; narHash = \"$hash\"; })) ? submodules)" 2>&1 | grep 'true'
|
2020-03-30 14:04:18 +00:00
|
|
|
|
|
2024-02-19 12:15:49 +00:00
|
|
|
|
nix-instantiate --eval -E '1 + 2' -I fnord=file:///no-such-tarball.tar$ext
|
|
|
|
|
nix-instantiate --eval -E 'with <fnord/xyzzy>; 1 + 2' -I fnord=file:///no-such-tarball$ext
|
|
|
|
|
(! nix-instantiate --eval -E '<fnord/xyzzy> 1' -I fnord=file:///no-such-tarball$ext)
|
2019-12-13 08:29:33 +00:00
|
|
|
|
|
2024-02-19 12:15:49 +00:00
|
|
|
|
nix-instantiate --eval -E '<fnord/config.nix>' -I fnord=file:///no-such-tarball$ext -I fnord=.
|
2021-07-08 11:29:58 +00:00
|
|
|
|
|
|
|
|
|
# Ensure that the `name` attribute isn’t accepted as that would mess
|
|
|
|
|
# with the content-addressing
|
|
|
|
|
(! nix-instantiate --eval -E "fetchTree { type = \"tarball\"; url = file://$tarball; narHash = \"$hash\"; name = \"foo\"; }")
|
|
|
|
|
|
2024-07-05 15:26:58 +00:00
|
|
|
|
store_path=$(nix store prefetch-file --json "file://$tarball" | jq -r .storePath)
|
|
|
|
|
if ! cmp -s "$store_path" "$tarball"; then
|
|
|
|
|
echo "prefetched tarball differs from original: $store_path vs $tarball" >&2
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
store_path2=$(nix store prefetch-file --json --unpack "file://$tarball" | jq -r .storePath)
|
|
|
|
|
diff_output=$(diff -r "$store_path2" "$tarroot")
|
|
|
|
|
if [ -n "$diff_output" ]; then
|
|
|
|
|
echo "prefetched tarball differs from original: $store_path2 vs $tarroot" >&2
|
|
|
|
|
echo "$diff_output"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2019-12-13 16:26:58 +00:00
|
|
|
|
}
|
2019-12-13 08:29:33 +00:00
|
|
|
|
|
2019-12-13 16:26:58 +00:00
|
|
|
|
test_tarball '' cat
|
|
|
|
|
test_tarball .xz xz
|
|
|
|
|
test_tarball .gz gzip
|
2024-06-11 14:05:57 +00:00
|
|
|
|
|
|
|
|
|
# Test hard links.
|
2024-06-11 17:39:42 +00:00
|
|
|
|
# All entries in tree.tar.gz refer to the same file, and all have the same inode when unpacked by GNU tar.
|
|
|
|
|
# We don't preserve the hard links, because that's an optimization we think is not worth the complexity,
|
|
|
|
|
# so we only make sure that the contents are copied correctly.
|
2024-06-11 14:05:57 +00:00
|
|
|
|
path="$(nix flake prefetch --json "tarball+file://$(pwd)/tree.tar.gz" | jq -r .storePath)"
|
|
|
|
|
[[ $(cat "$path/a/b/foo") = bar ]]
|
|
|
|
|
[[ $(cat "$path/a/b/xyzzy") = bar ]]
|
|
|
|
|
[[ $(cat "$path/a/yyy") = bar ]]
|
|
|
|
|
[[ $(cat "$path/a/zzz") = bar ]]
|
|
|
|
|
[[ $(cat "$path/c/aap") = bar ]]
|
|
|
|
|
[[ $(cat "$path/fnord") = bar ]]
|
2024-07-26 18:24:58 +00:00
|
|
|
|
|
|
|
|
|
# Test a tarball that has multiple top-level directories.
|
|
|
|
|
rm -rf "$TEST_ROOT/tar_root"
|
|
|
|
|
mkdir -p "$TEST_ROOT/tar_root" "$TEST_ROOT/tar_root/foo" "$TEST_ROOT/tar_root/bar"
|
|
|
|
|
tar cvf "$TEST_ROOT/tar.tar" -C "$TEST_ROOT/tar_root" .
|
|
|
|
|
path="$(nix flake prefetch --json "tarball+file://$TEST_ROOT/tar.tar" | jq -r .storePath)"
|
|
|
|
|
[[ -d "$path/foo" ]]
|
|
|
|
|
[[ -d "$path/bar" ]]
|
|
|
|
|
|
2024-07-29 12:34:02 +00:00
|
|
|
|
# Test a tarball that has a single regular file.
|
2024-07-26 18:24:58 +00:00
|
|
|
|
rm -rf "$TEST_ROOT/tar_root"
|
|
|
|
|
mkdir -p "$TEST_ROOT/tar_root"
|
|
|
|
|
echo bar > "$TEST_ROOT/tar_root/foo"
|
|
|
|
|
chmod +x "$TEST_ROOT/tar_root/foo"
|
|
|
|
|
tar cvf "$TEST_ROOT/tar.tar" -C "$TEST_ROOT/tar_root" .
|
|
|
|
|
path="$(nix flake prefetch --refresh --json "tarball+file://$TEST_ROOT/tar.tar" | jq -r .storePath)"
|
|
|
|
|
[[ $(cat "$path/foo") = bar ]]
|
2024-10-14 12:10:36 +00:00
|
|
|
|
|
|
|
|
|
# Test a tarball with non-contiguous directory entries.
|
|
|
|
|
rm -rf "$TEST_ROOT/tar_root"
|
|
|
|
|
mkdir -p "$TEST_ROOT/tar_root/a/b"
|
|
|
|
|
echo foo > "$TEST_ROOT/tar_root/a/b/foo"
|
|
|
|
|
echo bla > "$TEST_ROOT/tar_root/bla"
|
|
|
|
|
tar cvf "$TEST_ROOT/tar.tar" -C "$TEST_ROOT/tar_root" .
|
|
|
|
|
echo abc > "$TEST_ROOT/tar_root/bla"
|
|
|
|
|
echo xyzzy > "$TEST_ROOT/tar_root/a/b/xyzzy"
|
|
|
|
|
tar rvf "$TEST_ROOT/tar.tar" -C "$TEST_ROOT/tar_root" ./a/b/xyzzy ./bla
|
|
|
|
|
path="$(nix flake prefetch --refresh --json "tarball+file://$TEST_ROOT/tar.tar" | jq -r .storePath)"
|
|
|
|
|
[[ $(cat "$path/a/b/xyzzy") = xyzzy ]]
|
|
|
|
|
[[ $(cat "$path/a/b/foo") = foo ]]
|
|
|
|
|
[[ $(cat "$path/bla") = abc ]]
|