diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-07-16T14·02+0200 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-07-16T14·02+0200 |
commit | 276a40b31f631c188d6dcbdf603a738e1380ff74 (patch) | |
tree | c4f9b03af7c156379bb10becef1431388c342530 /tests | |
parent | bb65460feb265be4d938c7dc724a76ef41a8bfaf (diff) |
Handle case collisions on case-insensitive systems
When running NixOps under Mac OS X, we need to be able to import store paths built on Linux into the local Nix store. However, HFS+ is usually case-insensitive, so if there are directories with file names that differ only in case, then importing will fail. The solution is to add a suffix ("~nix~case~hack~<integer>") to colliding files. For instance, if we have a directory containing xt_CONNMARK.h and xt_connmark.h, then the latter will be renamed to "xt_connmark.h~nix~case~hack~1". If a store path is dumped as a NAR, the suffixes are removed. Thus, importing and exporting via a case-insensitive Nix store is round-tripping. So when NixOps calls nix-copy-closure to copy the path to a Linux machine, you get the original file names back. Closes #119.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/case-hack.sh | 19 | ||||
-rw-r--r-- | tests/case.nar | bin | 0 -> 2416 bytes | |||
-rw-r--r-- | tests/local.mk | 2 |
3 files changed, 20 insertions, 1 deletions
diff --git a/tests/case-hack.sh b/tests/case-hack.sh new file mode 100644 index 000000000000..ebc7cb1d5d65 --- /dev/null +++ b/tests/case-hack.sh @@ -0,0 +1,19 @@ +source common.sh + +clearStore + +rm -rf $TEST_ROOT/case + +opts="--option use-case-hack true" + +# Check whether restoring and dumping a NAR that contains case +# collisions is round-tripping, even on a case-insensitive system. +nix-store $opts --restore $TEST_ROOT/case < case.nar +nix-store $opts --dump $TEST_ROOT/case > $TEST_ROOT/case.nar +cmp case.nar $TEST_ROOT/case.nar +[ "$(nix-hash $opts --type sha256 $TEST_ROOT/case)" = "$(nix-hash --flat --type sha256 case.nar)" ] + +# Check whether we detect true collisions (e.g. those remaining after +# removal of the suffix). +touch "$TEST_ROOT/case/xt_CONNMARK.h~nix~case~hack~3" +! nix-store $opts --dump $TEST_ROOT/case > /dev/null diff --git a/tests/case.nar b/tests/case.nar new file mode 100644 index 000000000000..22ff26db5afd --- /dev/null +++ b/tests/case.nar Binary files differdiff --git a/tests/local.mk b/tests/local.mk index add6d7b7b4da..65aa12637055 100644 --- a/tests/local.mk +++ b/tests/local.mk @@ -10,7 +10,7 @@ nix_tests = \ remote-store.sh export.sh export-graph.sh negative-caching.sh \ binary-patching.sh timeout.sh secure-drv-outputs.sh nix-channel.sh \ multiple-outputs.sh import-derivation.sh fetchurl.sh optimise-store.sh \ - binary-cache.sh nix-profile.sh repair.sh dump-db.sh + binary-cache.sh nix-profile.sh repair.sh dump-db.sh case-hack.sh # parallel.sh install-tests += $(foreach x, $(nix_tests), tests/$(x)) |