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
|
# Copyright 2013-2022 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)
import os
from spack import *
class Papyrus(CMakePackage):
"""Parallel Aggregate Persistent Storage"""
homepage = "https://code.ornl.gov/eck/papyrus"
url = "https://code.ornl.gov/eck/papyrus/repository/archive.tar.bz2?ref=v1.0.2"
git = "https://code.ornl.gov/eck/papyrus.git"
tags = ['e4s']
version('master', branch='master')
version('1.0.2', sha256='b6cfcff99f73ded8e4ca4b165bc182cd5cac60f0c0cf4f93649b77d074445645')
version('1.0.1', sha256='3772fd6f2c301faf78f18c5e4dc3dbac57eb361861b091579609b3fff9e0bb17')
version('1.0.0', sha256='5d57c0bcc80de48951e42460785783b882087a5714195599d773a6eabde5c4c4')
depends_on('mpi')
test_requires_compiler = True
def setup_run_environment(self, env):
if os.path.isdir(self.prefix.lib64):
lib_dir = self.prefix.lib64
else:
lib_dir = self.prefix.lib
env.prepend_path('CPATH', self.prefix.include)
env.prepend_path('LIBRARY_PATH', lib_dir)
env.prepend_path('LD_LIBRARY_PATH', lib_dir)
@run_after('install')
def cache_test_sources(self):
"""Copy the example source files after the package is installed to an
install test subdirectory for use during `spack test run`."""
self.cache_extra_test_sources([join_path('kv', 'tests')])
def run_example_tests(self):
"""Run all c & c++ stand alone test"""
example_dir = join_path(self.test_suite.current_test_cache_dir, 'kv', 'tests')
if not os.path.exists(example_dir):
print('Skipping all test')
return
if os.path.isdir(self.prefix.lib64):
lib_dir = self.prefix.lib64
else:
lib_dir = self.prefix.lib
example_list = ['01_open_close', '02_put_get', '03_barrier',
'04_delete', '05_fence', '06_signal',
'07_consistency', '08_protect', '09_cache',
'10_checkpoint', '11_restart', '12_free']
for example in example_list:
test_dir = join_path(self.test_suite.current_test_cache_dir,
'kv', 'tests', example)
test_example = 'test{0}.c'.format(example)
if not os.path.exists(test_dir):
print('Skipping {0} test'.format(example))
continue
self.run_test(self.spec['mpi'].mpicxx,
options=['{0}'.format(join_path(test_dir, test_example)),
'-I{0}'.format(join_path(self.prefix, 'include')),
'-L{0}'.format(lib_dir), '-lpapyruskv', '-g', '-o',
example, '-lpthread', '-lm'],
purpose='test: compile {0} example'.format(example),
work_dir=test_dir)
self.run_test(self.spec['mpi'].prefix.bin.mpirun,
options=['-np', '4', example],
purpose='test: run {0} example'.format(example),
work_dir=test_dir)
def test(self):
self.run_example_tests()
|