pythonPackages.datatable: 0.10.1 -> 0.11.0, fix build

once we've made some alterations to the source (which doesn't seem to have
been shipped in a ready-to-build state), we can use the funny custom build
system to build a wheel which can then be installed by the pipInstallHook.

running the tests is again annoying because an ini file setting pytest's
python_files parameter is missing, meaning we have to inject our own.
This commit is contained in:
Robert Scott 2020-09-24 22:47:07 +01:00 committed by Jon
parent 3821543de7
commit d7365fad89
3 changed files with 41 additions and 65 deletions

View File

@ -1,45 +1,63 @@
{ stdenv, lib, buildPythonPackage, fetchPypi, substituteAll, pythonOlder { stdenv, lib, buildPythonPackage, fetchPypi, substituteAll, pythonOlder
, pipInstallHook, writeText
, blessed , blessed
, docutils , docutils
, libcxx , libcxx
, libcxxabi
, llvm , llvm
, openmp , pytestCheckHook
, pytest
, typesentry , typesentry
}: }:
buildPythonPackage rec { buildPythonPackage rec {
pname = "datatable"; pname = "datatable";
version = "0.10.1"; version = "0.11.0";
disabled = pythonOlder "3.5"; disabled = pythonOlder "3.5";
src = fetchPypi { src = fetchPypi {
inherit pname version; inherit pname version;
sha256 = "3ce5257c0c4afa96e2b14ca47a0aaf73add195b11de48f4adda50b5ede927436"; sha256 = "19c602711e00f72e9ae296d8fa742d46da037c2d3a2d254bdf68f817a8da76bb";
}; };
# authors seem to have created their own build system
format = "other";
patches = lib.optionals stdenv.isDarwin [ # tarball doesn't appear to have been shipped totally ready-to-build
# Replace the library auto-detection with hardcoded paths. postPatch = ''
(substituteAll { substituteInPlace ci/ext.py \
src = ./hardcode-library-paths.patch; --replace \
'shell_cmd(["git"' \
'"0000000000000000000000000000000000000000" or shell_cmd(["git"'
echo '${version}' > VERSION.txt
'';
DT_RELEASE = "1";
libomp_dylib = "${lib.getLib openmp}/lib/libomp.dylib"; buildPhase = ''
libcxx_dylib = "${lib.getLib libcxx}/lib/libc++.1.dylib"; python ci/ext.py wheel
libcxxabi_dylib = "${lib.getLib libcxxabi}/lib/libc++abi.dylib"; '';
})
];
propagatedBuildInputs = [ typesentry blessed ]; propagatedBuildInputs = [ typesentry blessed ];
buildInputs = [ llvm ] ++ lib.optionals stdenv.isDarwin [ openmp ]; buildInputs = [ llvm pipInstallHook ];
checkInputs = [ docutils pytest ]; checkInputs = [ docutils pytestCheckHook ];
LLVM = llvm; LLVM = llvm;
NIX_CFLAGS_COMPILE = lib.optionalString stdenv.isDarwin "-isystem ${libcxx}/include/c++/v1";
checkPhase = '' pytestFlagsArray = let
mv datatable datatable.hidden # ini file (not included in tarball) required to change python_files setting,
pytest pytestIni = writeText "pytest.ini" ''
''; [pytest]
python_files = test_*.py test-*.py
'';
in [
"-c ${pytestIni}"
];
disabledTests = [
# skip tests which are irrelevant to our installation or use way too much memory
"test_xfunction_paths"
"test_fread_from_cmd2"
"test_cast_huge_to_str"
"test_create_large_string_column"
];
pythonImportsCheck = [ "datatable" ];
meta = with lib; { meta = with lib; {
description = "data.table for Python"; description = "data.table for Python";

View File

@ -1,43 +0,0 @@
diff --git a/ci/setup_utils.py b/ci/setup_utils.py
index 66b385a..6255af0 100644
--- a/ci/setup_utils.py
+++ b/ci/setup_utils.py
@@ -600,37 +600,7 @@ def find_linked_dynamic_libraries():
them as a list of absolute paths.
"""
with TaskContext("Find the required dynamic libraries") as log:
- llvm = get_llvm()
- libs = required_link_libraries()
- resolved = []
- for libname in libs:
- if llvm:
- fullpath = os.path.join(llvm, "lib", libname)
- if os.path.isfile(fullpath):
- resolved.append(fullpath)
- log.info("Library `%s` found at %s" % (libname, fullpath))
- continue
- else:
- log.info("%s does not exist" % fullpath)
- # Rely on the shell `locate` command to find the dynamic libraries.
- proc = subprocess.Popen(["locate", libname], stdout=subprocess.PIPE,
- stderr=subprocess.PIPE)
- stdout, stderr = proc.communicate()
- if proc.returncode == 0:
- results = stdout.decode().strip().split("\n")
- results = [r for r in results if r]
- if results:
- results.sort(key=len)
- fullpath = results[0]
- assert os.path.isfile(fullpath), "Invalid path: %r" % (fullpath,)
- resolved.append(fullpath)
- log.info("Library `%s` found at %s" % (libname, fullpath))
- continue
- else:
- log.fatal("Cannot locate dynamic library `%s`" % libname)
- else:
- log.fatal("`locate` command returned the following error:\n%s"
- % stderr.decode())
+ resolved = ["@libomp_dylib@", "@libcxx_dylib@", "@libcxxabi_dylib@"]
return resolved

View File

@ -1459,8 +1459,9 @@ in {
datashape = callPackage ../development/python-modules/datashape { }; datashape = callPackage ../development/python-modules/datashape { };
datatable = datatable = callPackage ../development/python-modules/datatable {
callPackage ../development/python-modules/datatable { inherit (pkgs.llvmPackages) openmp libcxx libcxxabi; }; inherit (pkgs.llvmPackages) libcxx;
};
dateparser = callPackage ../development/python-modules/dateparser { }; dateparser = callPackage ../development/python-modules/dateparser { };