summary refs log tree commit diff
path: root/pkgs/test
diff options
context:
space:
mode:
authorBenjamin Saunders <benjamin.saunders@here.com>2018-05-30 18:48:42 -0700
committerBenjamin Saunders <benjamin.saunders@here.com>2018-05-30 18:48:42 -0700
commitf24f6d7af33d2ccc2942fba735e8de81c2ea268d (patch)
tree4a76fdb8f489a45ce809a0881a416c1191d4f37c /pkgs/test
parenta8ed1fc4edb6949c6eb0bdbf773c05f9b4a15a0c (diff)
downloadnixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.tar
nixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.tar.gz
nixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.tar.bz2
nixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.tar.lz
nixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.tar.xz
nixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.tar.zst
nixpkgs-f24f6d7af33d2ccc2942fba735e8de81c2ea268d.zip
tests.cc-wrapper: skip known-broken sanitizer cases
Diffstat (limited to 'pkgs/test')
-rw-r--r--pkgs/test/cc-wrapper/default.nix20
1 files changed, 13 insertions, 7 deletions
diff --git a/pkgs/test/cc-wrapper/default.nix b/pkgs/test/cc-wrapper/default.nix
index 87d070f5616..00b964940c8 100644
--- a/pkgs/test/cc-wrapper/default.nix
+++ b/pkgs/test/cc-wrapper/default.nix
@@ -1,6 +1,9 @@
 { stdenv }:
-
-stdenv.mkDerivation {
+with stdenv.lib;
+let
+  # Sanitizer headers aren't available in older libc++ stdenvs due to a bug
+  sanitizersBroken = stdenv.cc.isClang && builtins.compareVersions (getVersion stdenv.cc.name) "6.0.0" < 0;
+in stdenv.mkDerivation {
   name = "cc-wrapper-test";
 
   buildCommand = ''
@@ -15,7 +18,7 @@ stdenv.mkDerivation {
     $CXX -o cxx-check ${./cxx-main.cc}
     ./cxx-check
 
-    ${stdenv.lib.optionalString (stdenv.isDarwin && stdenv.cc.isClang) ''
+    ${optionalString (stdenv.isDarwin && stdenv.cc.isClang) ''
       printf "checking whether compiler can build with CoreFoundation.framework... " >&2
       mkdir -p foo/lib
       $CC -framework CoreFoundation -o core-foundation-check ${./core-foundation-main.c}
@@ -31,7 +34,7 @@ stdenv.mkDerivation {
     printf "checking whether compiler uses NIX_LDFLAGS... " >&2
     mkdir -p foo/lib
     $CC -shared \
-      ${stdenv.lib.optionalString stdenv.isDarwin "-Wl,-install_name,@rpath/libfoo.dylib"} \
+      ${optionalString stdenv.isDarwin "-Wl,-install_name,@rpath/libfoo.dylib"} \
       -DVALUE=42 \
       -o foo/lib/libfoo${stdenv.hostPlatform.extensions.sharedLibrary} \
       ${./foo.c}
@@ -39,11 +42,14 @@ stdenv.mkDerivation {
     NIX_LDFLAGS="-L$NIX_BUILD_TOP/foo/lib -rpath $NIX_BUILD_TOP/foo/lib" $CC -lfoo -o ldflags-check ${./ldflags-main.c}
     ./ldflags-check
 
-    $CC -o sanitizers -fsanitize=address,undefined ${./sanitizers.c}
-    ./sanitizers
+    ${optionalString (!sanitizersBroken) ''
+      printf "checking whether sanitizers are fully functional... ">&2
+      $CC -o sanitizers -fsanitize=address,undefined ${./sanitizers.c}
+      ./sanitizers
+    ''}
 
     touch $out
   '';
 
-  meta.platforms = stdenv.lib.platforms.all;
+  meta.platforms = platforms.all;
 }