nixpkgs/pkgs/development/interpreters/bats/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

217 lines
5.7 KiB
Nix
Raw Normal View History

{ resholve
2022-01-09 18:44:08 +00:00
, lib
2022-02-25 04:44:30 +00:00
, stdenv
2022-01-09 18:44:08 +00:00
, fetchFromGitHub
, bash
, coreutils
, gnugrep
, ncurses
, findutils
, hostname
, parallel
, flock
2022-09-18 17:18:27 +00:00
, procps
, bats
2022-02-25 04:44:30 +00:00
, lsof
, callPackages
, symlinkJoin
, makeWrapper
, runCommand
2022-01-09 18:44:08 +00:00
, doInstallCheck ? true
}:
2016-02-07 11:11:31 +00:00
resholve.mkDerivation rec {
pname = "bats";
2023-07-18 00:50:14 +00:00
version = "1.10.0";
2016-02-07 11:11:31 +00:00
2022-01-07 16:11:59 +00:00
src = fetchFromGitHub {
owner = "bats-core";
repo = "bats-core";
rev = "v${version}";
2023-07-18 00:50:14 +00:00
sha256 = "sha256-gy4dyoKRlf2WFmH1/mSNwhVR3df92BgpT4TjTpV4FyQ=";
2016-02-07 11:11:31 +00:00
};
2018-10-27 13:18:53 +00:00
patchPhase = ''
2021-01-12 01:29:36 +00:00
patchShebangs .
'';
2021-01-12 01:29:36 +00:00
installPhase = ''
./install.sh $out
2018-10-27 13:18:53 +00:00
'';
2022-01-09 18:44:08 +00:00
solutions = {
bats = {
scripts = [
"bin/bats"
"libexec/bats-core/*"
"lib/bats-core/*"
];
2022-01-09 18:44:08 +00:00
interpreter = "${bash}/bin/bash";
inputs = [
bash
coreutils
gnugrep
ncurses
findutils
hostname
parallel
flock
"lib/bats-core"
"libexec/bats-core"
2022-09-18 17:18:27 +00:00
procps
];
2022-01-09 18:44:08 +00:00
fake = {
external = [
"greadlink"
"shlock"
2022-09-18 17:18:27 +00:00
"pkill" # procps doesn't supply this on darwin
];
2022-01-09 18:44:08 +00:00
};
fix = {
"$BATS_ROOT" = [ "${placeholder "out"}" ];
"$BATS_LIBEXEC" = [ "${placeholder "out"}/libexec/bats-core" ];
2022-01-09 18:44:08 +00:00
};
keep = {
"${placeholder "out"}/libexec/bats-core/bats" = true;
source = [
"${placeholder "out"}/lib/bats-core/validator.bash"
"${placeholder "out"}/lib/bats-core/preprocessing.bash"
"$BATS_TEST_SOURCE"
"${placeholder "out"}/lib/bats-core/tracing.bash"
"${placeholder "out"}/lib/bats-core/test_functions.bash"
"$library_load_path"
"${placeholder "out"}/lib/bats-core/common.bash"
"${placeholder "out"}/lib/bats-core/semaphore.bash"
"${placeholder "out"}/lib/bats-core/formatter.bash"
2022-05-16 15:35:28 +00:00
"${placeholder "out"}/lib/bats-core/warnings.bash"
"$setup_suite_file" # via cli arg
];
2022-09-18 17:18:27 +00:00
"$interpolated_report_formatter" = true;
"$interpolated_formatter" = true;
"$pre_command" = true;
"$BATS_TEST_NAME" = true;
"${placeholder "out"}/libexec/bats-core/bats-exec-test" = true;
2023-03-09 09:12:48 +00:00
"$BATS_LINE_REFERENCE_FORMAT" = "comma_line";
"$BATS_LOCKING_IMPLEMENTATION" = "${flock}/bin/flock";
2023-07-18 00:50:14 +00:00
"$parallel_binary_name" = "${parallel}/bin/parallel";
2022-01-09 18:44:08 +00:00
};
execer = [
/*
both blatant lies for expedience; these can certainly exec args
they may be safe here, because they may always run things that
are ultimately in libexec?
TODO: handle parallel and flock in binlore/resholve
*/
"cannot:${parallel}/bin/parallel"
"cannot:${flock}/bin/flock"
"cannot:libexec/bats-core/bats-preprocess"
# these do exec, but other internal files
"cannot:libexec/bats-core/bats-exec-file"
"cannot:libexec/bats-core/bats-exec-suite"
];
2022-01-09 18:44:08 +00:00
};
};
passthru.libraries = callPackages ./libraries.nix {};
passthru.withLibraries = selector:
symlinkJoin {
name = "bats-with-libraries-${bats.version}";
paths = [
bats
] ++ selector bats.libraries;
nativeBuildInputs = [
makeWrapper
];
postBuild = ''
wrapProgram "$out/bin/bats" \
--suffix BATS_LIB_PATH : "$out/share/bats"
'';
};
passthru.tests.libraries = runCommand "${bats.name}-with-libraries-test" {
testScript = ''
setup() {
bats_load_library bats-support
bats_load_library bats-assert
2023-03-11 09:48:09 +00:00
bats_load_library bats-file
bats_require_minimum_version 1.5.0
2023-03-11 09:48:09 +00:00
TEST_TEMP_DIR="$(temp_make --prefix 'nixpkgs-bats-test')"
}
teardown() {
temp_del "$TEST_TEMP_DIR"
}
@test echo_hi {
run -0 echo hi
assert_output "hi"
}
@test cp_failure {
run ! cp
assert_line --index 0 "cp: missing file operand"
assert_line --index 1 "Try 'cp --help' for more information."
}
2023-03-11 09:48:09 +00:00
@test file_exists {
echo "hi" > "$TEST_TEMP_DIR/hello.txt"
assert_file_exist "$TEST_TEMP_DIR/hello.txt"
run cat "$TEST_TEMP_DIR/hello.txt"
assert_output "hi"
}
'';
passAsFile = [ "testScript" ];
} ''
2023-03-11 09:48:09 +00:00
${bats.withLibraries (p: [ p.bats-support p.bats-assert p.bats-file ])}/bin/bats "$testScriptPath"
touch "$out"
'';
passthru.tests.upstream = bats.unresholved.overrideAttrs (old: {
name = "${bats.name}-tests";
2022-05-16 15:35:28 +00:00
dontInstall = true; # just need the build directory
nativeInstallCheckInputs = [
ncurses
parallel # skips some tests if it can't detect
flock # skips some tests if it can't detect
2022-09-18 17:18:27 +00:00
procps
] ++ lib.optionals stdenv.isDarwin [ lsof ];
inherit doInstallCheck;
installCheckPhase = ''
# TODO: cut if https://github.com/bats-core/bats-core/issues/418 allows
sed -i '/test works even if PATH is reset/a skip "disabled for nix build"' test/bats.bats
# skip tests that assume bats `install.sh` will be in BATS_ROOT
rm test/root.bats
2022-09-18 17:18:27 +00:00
'' + (lib.optionalString stdenv.hostPlatform.isDarwin ''
# skip new timeout tests which are failing on macOS for unclear reasons
# This might relate to procps not having a pkill?
rm test/timeout.bats
'') + ''
# test generates file with absolute shebang dynamically
substituteInPlace test/install.bats --replace \
"/usr/bin/env bash" "${bash}/bin/bash"
${bats}/bin/bats test
touch $out
'';
});
2016-02-07 11:11:31 +00:00
2021-01-12 01:29:36 +00:00
meta = with lib; {
homepage = "https://github.com/bats-core/bats-core";
2016-02-07 11:11:31 +00:00
description = "Bash Automated Testing System";
2021-01-12 01:29:36 +00:00
maintainers = with maintainers; [ abathur ];
2016-02-07 11:11:31 +00:00
license = licenses.mit;
platforms = platforms.unix;
};
}