102 lines
2.2 KiB
Nix
102 lines
2.2 KiB
Nix
|
{
|
||
|
lib,
|
||
|
stdenv,
|
||
|
buildPythonPackage,
|
||
|
duckdb,
|
||
|
fsspec,
|
||
|
google-cloud-storage,
|
||
|
numpy,
|
||
|
openssl,
|
||
|
pandas,
|
||
|
psutil,
|
||
|
pybind11,
|
||
|
setuptools-scm,
|
||
|
pytestCheckHook,
|
||
|
}:
|
||
|
|
||
|
buildPythonPackage rec {
|
||
|
inherit (duckdb)
|
||
|
patches
|
||
|
pname
|
||
|
rev
|
||
|
src
|
||
|
version
|
||
|
;
|
||
|
pyproject = true;
|
||
|
|
||
|
postPatch =
|
||
|
(duckdb.postPatch or "")
|
||
|
+ ''
|
||
|
# we can't use sourceRoot otherwise patches don't apply, because the patches apply to the C++ library
|
||
|
cd tools/pythonpkg
|
||
|
|
||
|
# 1. let nix control build cores
|
||
|
# 2. default to extension autoload & autoinstall disabled
|
||
|
substituteInPlace setup.py \
|
||
|
--replace-fail "ParallelCompile()" 'ParallelCompile("NIX_BUILD_CORES")' \
|
||
|
--replace-fail "define_macros.extend([('DUCKDB_EXTENSION_AUTOLOAD_DEFAULT', '1'), ('DUCKDB_EXTENSION_AUTOINSTALL_DEFAULT', '1')])" "pass"
|
||
|
'';
|
||
|
|
||
|
env = {
|
||
|
BUILD_HTTPFS = 1;
|
||
|
DUCKDB_BUILD_UNITY = 1;
|
||
|
OVERRIDE_GIT_DESCRIBE = "v${version}-0-g${rev}";
|
||
|
};
|
||
|
|
||
|
nativeBuildInputs = [
|
||
|
pybind11
|
||
|
setuptools-scm
|
||
|
];
|
||
|
|
||
|
buildInputs = [ openssl ];
|
||
|
|
||
|
propagatedBuildInputs = [
|
||
|
numpy
|
||
|
pandas
|
||
|
];
|
||
|
|
||
|
nativeCheckInputs = [
|
||
|
fsspec
|
||
|
google-cloud-storage
|
||
|
psutil
|
||
|
pytestCheckHook
|
||
|
];
|
||
|
|
||
|
# test flags from .github/workflows/Python.yml
|
||
|
pytestFlagsArray = [ "--verbose" ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ "tests/fast" ];
|
||
|
|
||
|
disabledTestPaths = [
|
||
|
# avoid dependency on mypy
|
||
|
"tests/stubs/test_stubs.py"
|
||
|
];
|
||
|
|
||
|
disabledTests = [
|
||
|
# tries to make http request
|
||
|
"test_install_non_existent_extension"
|
||
|
|
||
|
# test is flaky https://github.com/duckdb/duckdb/issues/11961
|
||
|
"test_fetchmany"
|
||
|
|
||
|
# https://github.com/duckdb/duckdb/issues/10702
|
||
|
# tests are racy and interrupt can be delivered before or after target point
|
||
|
# causing a later test to fail with a spurious KeyboardInterrupt
|
||
|
"test_connection_interrupt"
|
||
|
"test_query_interruption"
|
||
|
];
|
||
|
|
||
|
# remove duckdb dir to prevent import confusion by pytest
|
||
|
preCheck = ''
|
||
|
export HOME="$(mktemp -d)"
|
||
|
rm -rf duckdb
|
||
|
'';
|
||
|
|
||
|
pythonImportsCheck = [ "duckdb" ];
|
||
|
|
||
|
meta = with lib; {
|
||
|
description = "Python binding for DuckDB";
|
||
|
homepage = "https://duckdb.org/";
|
||
|
license = licenses.mit;
|
||
|
maintainers = with maintainers; [ cpcloud ];
|
||
|
};
|
||
|
}
|