nixpkgs/pkgs/by-name/sh/shunit2/package.nix
aleksana 571c71e6f7 treewide: migrate packages to pkgs/by-name, take 1
We are migrating packages that meet below requirements:

1. using `callPackage`
2. called path is a directory
3. overriding set is empty (`{ }`)
4. not containing path expressions other than relative path (to
makenixpkgs-vet happy)
5. not referenced by nix files outside of the directory, other
than`pkgs/top-level/all-packages.nix`
6. not referencing nix files outside of the directory
7. not referencing `default.nix` (since it's changed to `package.nix`)
8. `outPath` doesn't change after migration

The tool is here: https://github.com/Aleksanaa/by-name-migrate.
2024-11-09 20:04:51 +08:00

92 lines
2.4 KiB
Nix

{ lib
, resholve
, fetchFromGitHub
, bash
, coreutils
, gnused
, gnugrep
, findutils
, ncurses
}:
resholve.mkDerivation rec {
pname = "shunit2";
version = "2.1.8";
src = fetchFromGitHub {
owner = "kward";
repo = pname;
rev = "v${version}";
hash = "sha256-IZHkgkVqzeh+eEKCDJ87sqNhSA+DU6kBCNDdQaUEeiM=";
};
installPhase = ''
mkdir -p $out/bin/
cp ./shunit2 $out/bin/shunit2
chmod +x $out/bin/shunit2
'';
doInstallCheck = true;
installCheckPhase = ''
$out/bin/shunit2
'';
solutions = {
shunit = {
# Caution: see __SHUNIT_CMD_ECHO_ESC before changing
interpreter = "${bash}/bin/sh";
scripts = [ "bin/shunit2" ];
inputs = [ coreutils gnused gnugrep findutils ncurses ];
# resholve's Nix API is analogous to the CLI flags
# documented in 'man resholve'
fake = {
# "missing" functions shunit2 expects the user to declare
function = [
"oneTimeSetUp"
"oneTimeTearDown"
"setUp"
"tearDown"
"suite"
"noexec"
];
# shunit2 is both bash and zsh compatible, and in
# some zsh-specific code it uses this non-bash builtin
builtin = [ "setopt" ];
};
fix = {
# stray absolute path; make it resolve from coreutils
"/usr/bin/od" = true;
/*
Caution: this one is contextually debatable. shunit2
sets this variable after testing whether `echo -e test`
yields `test` or `-e test`. Since we're setting the
interpreter, we can pre-test this. But if we go fiddle
the interpreter later, I guess we _could_ break it.
*/
"$__SHUNIT_CMD_ECHO_ESC" = [ "echo -e" ];
"$SHUNIT_CMD_TPUT" = [ "tput" ]; # from ncurses
};
keep = {
# dynamically defined in shunit2:_shunit_mktempFunc
eval = [ "shunit_condition_" "_shunit_test_" "_shunit_prepForSourcing" ];
# dynamic based on CLI flag
"$_SHUNIT_LINENO_" = true;
};
execer = [
# drop after https://github.com/abathur/binlore/issues/2
"cannot:${ncurses}/bin/tput"
];
};
};
meta = with lib; {
homepage = "https://github.com/kward/shunit2";
description = "XUnit based unit test framework for Bourne based shell scripts";
maintainers = with maintainers; [ abathur utdemir ];
license = licenses.asl20;
platforms = platforms.unix;
mainProgram = "shunit2";
};
}