71 lines
1.7 KiB
Nix
71 lines
1.7 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
buildPostgresqlExtension,
|
|
fetchFromGitHub,
|
|
perl,
|
|
perlPackages,
|
|
postgresql,
|
|
postgresqlTestHook,
|
|
which,
|
|
}:
|
|
|
|
buildPostgresqlExtension (finalAttrs: {
|
|
pname = "pgtap";
|
|
version = "1.3.3";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "theory";
|
|
repo = "pgtap";
|
|
rev = "v${finalAttrs.version}";
|
|
sha256 = "sha256-YgvfLGF7pLVcCKD66NnWAydDxtoYHH1DpLiYTEKHJ0E=";
|
|
};
|
|
|
|
nativeBuildInputs = [
|
|
postgresql
|
|
perl
|
|
perlPackages.TAPParserSourceHandlerpgTAP
|
|
which
|
|
];
|
|
|
|
passthru.tests.extension = stdenv.mkDerivation {
|
|
name = "pgtap-test";
|
|
dontUnpack = true;
|
|
doCheck = true;
|
|
nativeCheckInputs = [
|
|
postgresqlTestHook
|
|
(postgresql.withPackages (_: [ finalAttrs.finalPackage ]))
|
|
];
|
|
passAsFile = [ "sql" ];
|
|
sql = ''
|
|
CREATE EXTENSION pgtap;
|
|
|
|
BEGIN;
|
|
SELECT plan(1);
|
|
SELECT pass('Test passed');
|
|
SELECT * FROM finish();
|
|
ROLLBACK;
|
|
'';
|
|
failureHook = "postgresqlStop";
|
|
checkPhase = ''
|
|
runHook preCheck
|
|
psql -a -v ON_ERROR_STOP=1 -f $sqlPath
|
|
runHook postCheck
|
|
'';
|
|
installPhase = "touch $out";
|
|
};
|
|
|
|
meta = with lib; {
|
|
description = "Unit testing framework for PostgreSQL";
|
|
longDescription = ''
|
|
pgTAP is a unit testing framework for PostgreSQL written in PL/pgSQL and PL/SQL.
|
|
It includes a comprehensive collection of TAP-emitting assertion functions,
|
|
as well as the ability to integrate with other TAP-emitting test frameworks.
|
|
It can also be used in the xUnit testing style.
|
|
'';
|
|
maintainers = with maintainers; [ willibutz ];
|
|
homepage = "https://pgtap.org";
|
|
inherit (postgresql.meta) platforms;
|
|
license = licenses.mit;
|
|
};
|
|
})
|