summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/h5bench/package.py
blob: c367bbaf8ebae750b23508ba2d7bb6b65a4aa8a9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
# Copyright 2013-2024 Lawrence Livermore National Security, LLC and other
# Spack Project Developers. See the top-level COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)

from spack.package import *


class H5bench(CMakePackage):
    """A benchmark suite for measuring HDF5 performance."""

    homepage = "https://github.com/hpc-io/h5bench"
    git = "https://github.com/hpc-io/h5bench.git"

    maintainers("jeanbez", "sbyna")

    tags = ["e4s"]

    license("BSD-3-Clause-LBNL")

    version("latest", branch="master", submodules=True)
    version("develop", branch="develop", submodules=True)

    version("1.4", commit="67a3e6d91508e5ab77db79c6187b2eb3c96119e0", submodules=True)
    version("1.3", commit="ec75a466a77c337b4252c0afe1055c7fbe841e16", submodules=True)
    version(
        "1.2", commit="866af6777573d20740d02acc47a9080de093e4ad", submodules=True, deprecated=True
    )
    version(
        "1.1", commit="1276530a128025b83a4d9e3814a98f92876bb5c4", submodules=True, deprecated=True
    )
    version(
        "1.0", commit="9d3438c1bc66c5976279ef203bd11a8d48ade724", submodules=True, deprecated=True
    )

    variant("metadata", default=False, when="@1.2:", description="Enables metadata benchmark")
    variant("amrex", default=False, when="@1.2:", description="Enables AMReX benchmark")
    variant("exerciser", default=False, when="@1.2:", description="Enables exerciser benchmark")
    variant("openpmd", default=False, when="@1.2:", description="Enables OpenPMD benchmark")
    variant("e3sm", default=False, when="@1.2:", description="Enables E3SM benchmark")
    variant("async", default=False, when="@1.2:", description="Enables ASYNC VOL Connector")
    variant("all", default=False, when="@1.2:", description="Enables all h5bench benchmarks")

    depends_on("cmake@3.10:", type="build")
    depends_on("mpi")
    depends_on("hdf5+mpi@1.12.0:1,develop-1.12:")
    depends_on("hdf5-vol-async@1.5", when="+async")
    depends_on("parallel-netcdf", when="+e3sm")
    depends_on("parallel-netcdf", when="+all")

    def setup_build_environment(self, env):
        env.set("HDF5_HOME", self.spec["hdf5"].prefix)

    def cmake_args(self):
        args = [
            self.define_from_variant("H5BENCH_METADATA", "metadata"),
            self.define_from_variant("H5BENCH_AMREX", "amrex"),
            self.define_from_variant("H5BENCH_EXERCISER", "exerciser"),
            self.define_from_variant("H5BENCH_OPENPMD", "openpmd"),
            self.define_from_variant("H5BENCH_E3SM", "e3sm"),
            self.define_from_variant("H5BENCH_ALL", "all"),
            self.define_from_variant("WITH_ASYNC_VOL", "async"),
        ]

        return args

    @run_after("install")
    def setup_build_tests(self):
        launcher = self.mpi_launcher()
        filename = "samples/sync-write-1d-contig-contig.json"
        filter_file("mpirun", f"{launcher}", filename)
        filter_file(r"-n 2", "-n 1 --timeout 240", filename)

        """Copy the example source files after the package is installed to an
        install test subdirectory for use during `spack test run`."""
        cache_extra_test_sources(self, ["tests", "samples"])

    def mpi_launcher(self):
        commands = ["mpirun", "mpiexec"]

        return which(*commands, path=[self.spec["mpi"].prefix.bin]) or which(*commands)

    def test_help(self):
        """Run h5bench help."""
        h5bench = which(self.prefix.bin.h5bench)
        h5bench("-h")

    def test_h5bench(self):
        """Run h5bench synchronous write test."""
        with working_dir(self.test_suite.current_test_cache_dir):
            h5bench = which(self.prefix.bin.h5bench)
            h5bench("--debug", "--abort", "samples/sync-write-1d-contig-contig.json")