2024-06-05 15:53:02 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
stdenv,
|
|
|
|
buildPythonPackage,
|
|
|
|
fetchFromGitHub,
|
|
|
|
fetchurl,
|
|
|
|
pythonOlder,
|
|
|
|
substituteAll,
|
|
|
|
|
|
|
|
# build
|
|
|
|
postgresql,
|
|
|
|
setuptools,
|
|
|
|
|
|
|
|
# propagates
|
|
|
|
backports-zoneinfo,
|
|
|
|
typing-extensions,
|
|
|
|
|
|
|
|
# psycopg-c
|
|
|
|
cython,
|
|
|
|
tomli,
|
|
|
|
|
|
|
|
# docs
|
|
|
|
furo,
|
|
|
|
shapely,
|
|
|
|
sphinxHook,
|
|
|
|
sphinx-autodoc-typehints,
|
|
|
|
|
|
|
|
# tests
|
|
|
|
anyio,
|
|
|
|
pproxy,
|
|
|
|
pytest-randomly,
|
|
|
|
pytestCheckHook,
|
|
|
|
postgresqlTestHook,
|
2022-08-12 12:06:08 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
|
|
|
pname = "psycopg";
|
2024-02-07 01:22:34 +00:00
|
|
|
version = "3.1.17";
|
2022-08-12 12:06:08 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "psycopg";
|
|
|
|
repo = pname;
|
2022-09-09 14:08:57 +00:00
|
|
|
rev = "refs/tags/${version}";
|
2024-02-07 01:22:34 +00:00
|
|
|
hash = "sha256-Paq4Wkvv6d6+fNcvRO/yfj7OWCMygqccKIdfsohHUMM=";
|
2022-08-12 12:06:08 +00:00
|
|
|
};
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
patches = [
|
|
|
|
(substituteAll {
|
|
|
|
src = ./ctypes.patch;
|
|
|
|
libpq = "${postgresql.lib}/lib/libpq${stdenv.hostPlatform.extensions.sharedLibrary}";
|
|
|
|
libc = "${stdenv.cc.libc}/lib/libc.so.6";
|
|
|
|
})
|
|
|
|
];
|
|
|
|
|
|
|
|
baseMeta = {
|
2023-05-24 13:37:59 +00:00
|
|
|
changelog = "https://github.com/psycopg/psycopg/blob/${version}/docs/news.rst#current-release";
|
2022-09-09 14:08:57 +00:00
|
|
|
homepage = "https://github.com/psycopg/psycopg";
|
|
|
|
license = lib.licenses.lgpl3Plus;
|
|
|
|
maintainers = with lib.maintainers; [ hexa ];
|
|
|
|
};
|
|
|
|
|
|
|
|
psycopg-c = buildPythonPackage {
|
|
|
|
pname = "${pname}-c";
|
|
|
|
inherit version src;
|
|
|
|
format = "pyproject";
|
|
|
|
|
|
|
|
# apply patches to base repo
|
|
|
|
inherit patches;
|
|
|
|
|
|
|
|
# move into source root after patching
|
|
|
|
postPatch = ''
|
|
|
|
cd psycopg_c
|
|
|
|
'';
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
2024-04-21 15:54:59 +00:00
|
|
|
cython
|
2022-09-09 14:08:57 +00:00
|
|
|
postgresql
|
2023-02-02 18:25:31 +00:00
|
|
|
setuptools
|
|
|
|
tomli
|
2022-09-09 14:08:57 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
# tested in psycopg
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
meta = baseMeta // {
|
|
|
|
description = "C optimisation distribution for Psycopg";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
psycopg-pool = buildPythonPackage {
|
|
|
|
pname = "${pname}-pool";
|
|
|
|
inherit version src;
|
|
|
|
format = "setuptools";
|
|
|
|
|
|
|
|
# apply patches to base repo
|
|
|
|
inherit patches;
|
|
|
|
|
|
|
|
# move into source root after patching
|
|
|
|
postPatch = ''
|
|
|
|
cd psycopg_pool
|
|
|
|
'';
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
propagatedBuildInputs = [ typing-extensions ];
|
2022-09-09 14:08:57 +00:00
|
|
|
|
|
|
|
# tested in psycopg
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
meta = baseMeta // {
|
|
|
|
description = "Connection Pool for Psycopg";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
in
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
inherit pname version src;
|
|
|
|
format = "pyproject";
|
|
|
|
|
|
|
|
disabled = pythonOlder "3.7";
|
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
outputs = [
|
|
|
|
"out"
|
|
|
|
"doc"
|
|
|
|
];
|
|
|
|
|
|
|
|
sphinxRoot = "../docs";
|
|
|
|
|
|
|
|
# Introduce this file necessary for the docs build via environment var
|
|
|
|
LIBPQ_DOCS_FILE = fetchurl {
|
2024-04-21 15:54:59 +00:00
|
|
|
url = "https://raw.githubusercontent.com/postgres/postgres/496a1dc44bf1261053da9b3f7e430769754298b4/doc/src/sgml/libpq.sgml";
|
|
|
|
hash = "sha256-JwtCngkoi9pb0pqIdNgukY8GbG5pUDZvrGAHZqjFOw4";
|
2022-08-12 12:06:08 +00:00
|
|
|
};
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
inherit patches;
|
2022-08-12 12:06:08 +00:00
|
|
|
|
|
|
|
# only move to sourceRoot after patching, makes patching easier
|
|
|
|
postPatch = ''
|
2022-09-09 14:08:57 +00:00
|
|
|
cd psycopg
|
2022-08-12 12:06:08 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
|
|
|
furo
|
2022-09-09 14:08:57 +00:00
|
|
|
setuptools
|
2022-08-12 12:06:08 +00:00
|
|
|
shapely
|
|
|
|
sphinx-autodoc-typehints
|
2022-09-09 14:08:57 +00:00
|
|
|
sphinxHook
|
2022-08-12 12:06:08 +00:00
|
|
|
];
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
propagatedBuildInputs = [
|
|
|
|
psycopg-c
|
2022-08-12 12:06:08 +00:00
|
|
|
typing-extensions
|
2024-06-05 15:53:02 +00:00
|
|
|
] ++ lib.optionals (pythonOlder "3.9") [ backports-zoneinfo ];
|
2022-08-12 12:06:08 +00:00
|
|
|
|
|
|
|
pythonImportsCheck = [
|
|
|
|
"psycopg"
|
2022-09-09 14:08:57 +00:00
|
|
|
"psycopg_c"
|
|
|
|
"psycopg_pool"
|
2022-08-12 12:06:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
passthru.optional-dependencies = {
|
2022-09-09 14:08:57 +00:00
|
|
|
c = [ psycopg-c ];
|
|
|
|
pool = [ psycopg-pool ];
|
2022-08-12 12:06:08 +00:00
|
|
|
};
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
nativeCheckInputs =
|
|
|
|
[
|
|
|
|
anyio
|
|
|
|
pproxy
|
|
|
|
pytest-randomly
|
|
|
|
pytestCheckHook
|
|
|
|
postgresql
|
|
|
|
]
|
|
|
|
++ lib.optional (stdenv.isLinux) postgresqlTestHook
|
|
|
|
++ passthru.optional-dependencies.c
|
|
|
|
++ passthru.optional-dependencies.pool;
|
2022-08-12 12:06:08 +00:00
|
|
|
|
2023-05-24 13:37:59 +00:00
|
|
|
env = {
|
|
|
|
postgresqlEnableTCP = 1;
|
|
|
|
PGUSER = "psycopg";
|
2024-01-02 11:29:13 +00:00
|
|
|
PGDATABASE = "psycopg";
|
2023-05-24 13:37:59 +00:00
|
|
|
};
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
preCheck =
|
|
|
|
''
|
|
|
|
cd ..
|
|
|
|
''
|
|
|
|
+ lib.optionalString (stdenv.isLinux) ''
|
|
|
|
export PSYCOPG_TEST_DSN="host=/build/run/postgresql user=$PGUSER"
|
|
|
|
'';
|
2023-05-24 13:37:59 +00:00
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
disabledTests = [
|
2022-09-09 14:08:57 +00:00
|
|
|
# don't depend on mypy for tests
|
2022-08-12 12:06:08 +00:00
|
|
|
"test_version"
|
2022-09-09 14:08:57 +00:00
|
|
|
"test_package_version"
|
2022-08-12 12:06:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
disabledTestPaths = [
|
|
|
|
# Network access
|
|
|
|
"tests/test_dns.py"
|
|
|
|
"tests/test_dns_srv.py"
|
|
|
|
# Mypy typing test
|
|
|
|
"tests/test_typing.py"
|
2022-09-09 14:08:57 +00:00
|
|
|
"tests/crdb/test_typing.py"
|
2022-08-12 12:06:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
pytestFlagsArray = [
|
2024-06-05 15:53:02 +00:00
|
|
|
"-o"
|
|
|
|
"cache_dir=$TMPDIR"
|
|
|
|
"-m"
|
|
|
|
"'not refcount and not timing'"
|
2024-04-21 15:54:59 +00:00
|
|
|
# pytest.PytestRemovedIn9Warning: Marks applied to fixtures have no effect
|
2024-06-05 15:53:02 +00:00
|
|
|
"-W"
|
|
|
|
"ignore::pytest.PytestRemovedIn9Warning"
|
2022-08-12 12:06:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
postCheck = ''
|
|
|
|
cd ${pname}
|
|
|
|
'';
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
passthru = {
|
|
|
|
c = psycopg-c;
|
|
|
|
pool = psycopg-pool;
|
|
|
|
};
|
|
|
|
|
|
|
|
meta = baseMeta // {
|
2022-08-12 12:06:08 +00:00
|
|
|
description = "PostgreSQL database adapter for Python";
|
|
|
|
};
|
|
|
|
}
|