mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-04-14 11:07:42 +00:00
tests: add some cross tests
This commit is contained in:
parent
09fed91ec8
commit
b98b4eac71
80
pkgs/test/cross/default.nix
Normal file
80
pkgs/test/cross/default.nix
Normal file
@ -0,0 +1,80 @@
|
||||
{ pkgs, pkgsCross, lib }:
|
||||
|
||||
let
|
||||
|
||||
emulators = {
|
||||
mingw32 = "WINEDEBUG=-all ${pkgs.winePackages.minimal}/bin/wine";
|
||||
mingwW64 = "WINEDEBUG=-all ${pkgs.wineWowPackages.minimal}/bin/wine";
|
||||
# TODO: add some qemu-based emulaltors here
|
||||
};
|
||||
|
||||
getExecutable = pkgs: pkgFun: exec:
|
||||
"${pkgFun pkgs}${exec}${pkgs.hostPlatform.extensions.executable}";
|
||||
|
||||
compareTest = { emulator, pkgFun, hostPkgs, crossPkgs, exec, args ? [] }: let
|
||||
pkgName = (pkgFun hostPkgs).name;
|
||||
args' = lib.concatStringsSep " " args;
|
||||
in pkgs.runCommand "test-${pkgName}-${crossPkgs.hostPlatform.config}" {
|
||||
nativeBuildInputs = [ pkgs.dos2unix ];
|
||||
} ''
|
||||
HOME=$(pwd)
|
||||
mkdir -p $out
|
||||
|
||||
# We need to remove whitespace, unfortunately
|
||||
# Windows programs use \r but Unix programs use \n
|
||||
|
||||
# find expected value natively
|
||||
${getExecutable hostPkgs pkgFun exec} ${args'} \
|
||||
| dos2unix > $out/expected
|
||||
|
||||
# run emulator to get actual value
|
||||
${emulator} ${getExecutable crossPkgs pkgFun exec} ${args'} \
|
||||
| dos2unix > $out/actual
|
||||
|
||||
if [ "$(cat $out/actual)" != "$(cat $out/expected)" ]; then
|
||||
echo "${pkgName} did not output expected value:"
|
||||
cat $out/expected
|
||||
echo "instead it output:"
|
||||
cat $out/actual
|
||||
exit 1
|
||||
else
|
||||
echo "${pkgName} test passed"
|
||||
echo "both produced output:"
|
||||
cat $out/actual
|
||||
fi
|
||||
'';
|
||||
|
||||
in
|
||||
|
||||
lib.mapAttrs (name: emulator: let
|
||||
crossPkgs = pkgsCross.${name};
|
||||
|
||||
# Apply some transformation on windows to get dlls in the right
|
||||
# place. Unfortunately mingw doesn’t seem to be able to do linking
|
||||
# properly.
|
||||
platformFun = pkg: if crossPkgs.hostPlatform.isWindows then
|
||||
pkgs.buildEnv {
|
||||
name = "${pkg.name}-winlinks";
|
||||
paths = [pkg] ++ pkg.buildInputs;
|
||||
} else pkg;
|
||||
in {
|
||||
|
||||
hello = compareTest {
|
||||
inherit emulator crossPkgs;
|
||||
hostPkgs = pkgs;
|
||||
exec = "/bin/hello";
|
||||
pkgFun = pkgs: pkgs.hello;
|
||||
};
|
||||
|
||||
file = compareTest {
|
||||
inherit emulator crossPkgs;
|
||||
hostPkgs = pkgs;
|
||||
exec = "/bin/file";
|
||||
args = [
|
||||
"${pkgs.file}/share/man/man1/file.1.gz"
|
||||
"${pkgs.dejavu_fonts}/share/fonts/truetype/DejaVuMathTeXGyre.ttf"
|
||||
];
|
||||
pkgFun = pkgs: platformFun pkgs.file;
|
||||
};
|
||||
|
||||
}) emulators
|
@ -23,4 +23,6 @@ with pkgs;
|
||||
cc-multilib-clang = callPackage ./cc-wrapper/multilib.nix { stdenv = clangMultiStdenv; };
|
||||
|
||||
macOSSierraShared = callPackage ./macos-sierra-shared {};
|
||||
|
||||
cross = callPackage ./cross {};
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user