Skip to content

Commit

Permalink
Merge pull request #275416 from NixOS/pdal-tests
Browse files Browse the repository at this point in the history
pdal: enable unit and package tests
  • Loading branch information
K900 committed Jan 8, 2024
2 parents b439461 + e6ba94f commit d95f2f3
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 9 deletions.
65 changes: 56 additions & 9 deletions pkgs/development/libraries/pdal/default.nix
Original file line number Diff line number Diff line change
@@ -1,33 +1,37 @@
{ lib, stdenv
{ lib
, stdenv
, callPackage
, fetchFromGitHub
, fetchpatch
, testers

, enableE57 ? lib.meta.availableOn stdenv.hostPlatform libe57format

, cmake
, pkg-config
, openscenegraph
, curl
, gdal
, hdf5-cpp
, LASzip
, enableE57 ? lib.meta.availableOn stdenv.hostPlatform libe57format
, libe57format
, libgeotiff
, libtiff
, libxml2
, openscenegraph
, pkg-config
, postgresql
, tiledb
, xercesc
, zlib
, zstd
}:

stdenv.mkDerivation rec {
stdenv.mkDerivation (finalAttrs: {
pname = "pdal";
version = "2.5.6";

src = fetchFromGitHub {
owner = "PDAL";
repo = "PDAL";
rev = version;
rev = finalAttrs.version;
sha256 = "sha256-JKwa89c05EfZ/FxOkj8lYmw0o2EgSqafRDIV2mTpZ5E=";
};

Expand All @@ -37,14 +41,14 @@ stdenv.mkDerivation rec {
];

buildInputs = [
openscenegraph
curl
gdal
hdf5-cpp
LASzip
libgeotiff
libtiff
libxml2
openscenegraph
postgresql
tiledb
xercesc
Expand All @@ -59,6 +63,8 @@ stdenv.mkDerivation rec {
"-DBUILD_PLUGIN_HDF=ON"
"-DBUILD_PLUGIN_PGPOINTCLOUD=ON"
"-DBUILD_PLUGIN_TILEDB=ON"
"-DWITH_TESTS=ON"
"-DBUILD_PGPOINTCLOUD_TESTS=OFF"

# Plugins can probably not be made work easily:
"-DBUILD_PLUGIN_CPD=OFF"
Expand All @@ -75,11 +81,52 @@ stdenv.mkDerivation rec {
"-DBUILD_PLUGIN_RIVLIB=OFF"
];

doCheck = true;

disabledTests = [
# Tests failing due to TileDB library implementation, disabled also
# by upstream CI.
# See: https://github.com/PDAL/PDAL/blob/bc46bc77f595add4a6d568a1ff923d7fe20f7e74/.github/workflows/linux.yml#L81
"pdal_io_tiledb_writer_test"
"pdal_io_tiledb_reader_test"
"pdal_io_tiledb_time_writer_test"
"pdal_io_tiledb_time_reader_test"
"pdal_io_tiledb_bit_fields_test"
"pdal_io_e57_read_test"
"pdal_io_e57_write_test"
"pdal_io_stac_reader_test"

# Segfault
"pdal_io_hdf_reader_test"

# Failure
"pdal_app_plugin_test"
];

checkPhase = ''
runHook preCheck
# tests are flaky and they seem to fail less often when they don't run in
# parallel
ctest -j 1 --output-on-failure -E '^${lib.concatStringsSep "|" finalAttrs.disabledTests}$'
runHook postCheck
'';

passthru.tests = {
version = testers.testVersion {
package = finalAttrs.finalPackage;
command = "pdal --version";
version = "pdal ${finalAttrs.finalPackage.version}";
};
pdal = callPackage ./tests.nix { pdal = finalAttrs.finalPackage; };
pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage;
};

meta = with lib; {
description = "PDAL is Point Data Abstraction Library. GDAL for point cloud data";
homepage = "https://pdal.io";
license = licenses.bsd3;
maintainers = teams.geospatial.members;
platforms = platforms.all;
pkgConfigModules = [ "pdal" ];
};
}
})
10 changes: 10 additions & 0 deletions pkgs/development/libraries/pdal/tests.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{ runCommand, pdal }:

let
inherit (pdal) pname;
in
runCommand "${pname}-tests" { meta.timeout = 60; }
''
${pdal}/bin/pdal --drivers
touch $out
''

0 comments on commit d95f2f3

Please sign in to comment.