diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2010-11-17T18·01+0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2010-11-17T18·01+0000 |
commit | d92ccbf1ac5ab68937a0e411f4daee7e427865bd (patch) | |
tree | 41f4379167678c86c8392ba154ad06691fff8110 /tests/binary-patching.sh | |
parent | 1a211d812f1808a5a9128cbfd74bb59d07487b1c (diff) |
* Test whether sequences of patches work.
Diffstat (limited to 'tests/binary-patching.sh')
-rw-r--r-- | tests/binary-patching.sh | 47 |
1 files changed, 33 insertions, 14 deletions
diff --git a/tests/binary-patching.sh b/tests/binary-patching.sh index 26a499727fae..c320dccc7901 100644 --- a/tests/binary-patching.sh +++ b/tests/binary-patching.sh @@ -12,28 +12,47 @@ $NIX_BIN_DIR/nix-push --copy $TEST_ROOT/cache2 $TEST_ROOT/manifest1 \ out2=$($nixbuild -o $RESULT binary-patching.nix --arg version 2) $NIX_BIN_DIR/nix-push --copy $TEST_ROOT/cache2 $TEST_ROOT/manifest2 $out2 + +out3=$($nixbuild -o $RESULT binary-patching.nix --arg version 3) +$NIX_BIN_DIR/nix-push --copy $TEST_ROOT/cache2 $TEST_ROOT/manifest3 $out3 + rm $RESULT -# Generate a binary patch. +# Generate binary patches. $NIX_BIN_DIR/generate-patches.pl $TEST_ROOT/cache2 $TEST_ROOT/patches \ file://$TEST_ROOT/patches $TEST_ROOT/manifest1 $TEST_ROOT/manifest2 -grep -q "patch {" $TEST_ROOT/manifest2 +$NIX_BIN_DIR/generate-patches.pl $TEST_ROOT/cache2 $TEST_ROOT/patches \ + file://$TEST_ROOT/patches $TEST_ROOT/manifest2 $TEST_ROOT/manifest3 -# Get rid of version 2. -$nixstore --delete $out2 -! test -e $out2 +grep -q "patch {" $TEST_ROOT/manifest3 -# Pull the manifest containing the patch. -clearManifests -$NIX_BIN_DIR/nix-pull file://$TEST_ROOT/manifest2 +# Get rid of versions 2 and 3. +$nixstore --delete $out2 $out3 -# To make sure that we're using the patch, delete the full NARs. -rm -f $TEST_ROOT/cache2/* +# Pull the manifest containing the patches. +clearManifests +$NIX_BIN_DIR/nix-pull file://$TEST_ROOT/manifest3 -# Make sure that the download size prediction uses the patch rather +# Make sure that the download size prediction uses the patches rather # than the full download. -$nixbuild -o $RESULT binary-patching.nix --arg version 2 --dry-run 2>&1 | grep -q "0.01 MiB" +$nixbuild -o $RESULT binary-patching.nix --arg version 3 --dry-run 2>&1 | grep -q "0.01 MiB" -# Now rebuild it. This should use the patch generated above. -$nixbuild -o $RESULT binary-patching.nix --arg version 2 +# Now rebuild it. This should use the two patches generated above. +rm -f $TEST_ROOT/var/log/nix/downloads +$nixbuild -o $RESULT binary-patching.nix --arg version 3 +rm $RESULT +[ "$(grep ' patch ' $TEST_ROOT/var/log/nix/downloads | wc -l)" -eq 2 ] + +# Add a patch from version 1 directly to version 3. +$NIX_BIN_DIR/generate-patches.pl $TEST_ROOT/cache2 $TEST_ROOT/patches \ + file://$TEST_ROOT/patches $TEST_ROOT/manifest1 $TEST_ROOT/manifest3 + +# Rebuild version 3. This should use the direct patch rather than the +# sequence of two patches. +$nixstore --delete $out2 $out3 +clearManifests +rm $TEST_ROOT/var/log/nix/downloads +$NIX_BIN_DIR/nix-pull file://$TEST_ROOT/manifest3 +$nixbuild -o $RESULT binary-patching.nix --arg version 3 +[ "$(grep ' patch ' $TEST_ROOT/var/log/nix/downloads | wc -l)" -eq 1 ] |