2024-11-17 11:31:48 +01:00
|
|
|
"""test all benchmarks
|
|
|
|
"""
|
|
|
|
import unittest
|
|
|
|
import logging
|
|
|
|
import subprocess
|
|
|
|
import json
|
|
|
|
from pathlib import Path
|
2024-11-25 14:52:08 +01:00
|
|
|
from iprbench.core import BenchmarkConfig, BenchmarkId, HostTypeId
|
2024-11-17 11:31:48 +01:00
|
|
|
from shutil import rmtree
|
|
|
|
# import importlib.resources
|
|
|
|
|
|
|
|
|
|
|
|
def test_benchmark(benchmark_id: BenchmarkId, benchmark_config: BenchmarkConfig, results_root_path: Path):
|
|
|
|
logging.info('testing benchmark %s', benchmark_id)
|
|
|
|
results_dir = Path(f'{results_root_path}/{benchmark_id}')
|
|
|
|
if results_dir.exists():
|
|
|
|
rmtree(results_dir)
|
|
|
|
results_dir.mkdir(parents=True)
|
|
|
|
# output results into a tsv file
|
|
|
|
resultsdb_params = {
|
|
|
|
'type': 'tsv-files',
|
|
|
|
'tsv_results_dir': f'{results_dir / "results"}'
|
|
|
|
}
|
2024-11-25 14:52:08 +01:00
|
|
|
target_system_type_id = HostTypeId('debian')
|
|
|
|
command = f'iprbench-run --benchmark-id \'{benchmark_id}\' --config \'{json.dumps(benchmark_config)}\' --results-dir {results_dir} --resultsdb-params \'{json.dumps(resultsdb_params)}\' --target-system-type-id "{target_system_type_id}"'
|
2024-11-17 11:31:48 +01:00
|
|
|
subprocess.run(command, shell=True, check=True, executable='/bin/bash')
|
|
|
|
|
|
|
|
|
|
|
|
class BenchmarksTestCase(unittest.TestCase):
|
|
|
|
|
|
|
|
results_root_dir: Path
|
|
|
|
|
|
|
|
def setUp(self) -> None: # pylint: disable=useless-parent-delegation
|
|
|
|
self.results_root_dir = Path('/tmp/iprbenchs/test_results/benchmarks')
|
|
|
|
if self.results_root_dir.exists():
|
|
|
|
rmtree(self.results_root_dir)
|
|
|
|
self.results_root_dir.mkdir(parents=True)
|
|
|
|
return super().setUp()
|
|
|
|
|
|
|
|
def test_mamul1(self):
|
|
|
|
benchmark_id = 'mamul1'
|
|
|
|
benchmark_config = {
|
2024-11-19 21:37:55 +01:00
|
|
|
'fortran_compiler': 'gfortran:<default>',
|
2024-11-21 16:45:22 +01:00
|
|
|
'blas_library': '<default-libblas>:<default>',
|
2024-11-17 11:31:48 +01:00
|
|
|
'matrix_size': 1024,
|
|
|
|
'num_loops': 10,
|
2024-11-22 13:43:54 +01:00
|
|
|
'num_cores': 2,
|
|
|
|
'launcher': 'iprbench.unittest',
|
2024-11-17 11:31:48 +01:00
|
|
|
}
|
|
|
|
test_benchmark(benchmark_id, benchmark_config, self.results_root_dir)
|
|
|
|
|
2024-11-26 16:56:11 +01:00
|
|
|
def test_hibridon(self):
|
|
|
|
benchmark_id = 'hibridon'
|
2024-11-17 11:31:48 +01:00
|
|
|
benchmark_config = {
|
2024-11-19 21:37:55 +01:00
|
|
|
'fortran_compiler': 'gfortran:<default>',
|
2024-11-21 17:12:29 +01:00
|
|
|
'blas_library': '<default-libblas>:<default>',
|
2024-11-17 11:31:48 +01:00
|
|
|
'test_id': 'arch4_quick',
|
|
|
|
'hibridon_version': 'a3bed1c3ccfbca572003020d3e3d3b1ff3934fad',
|
|
|
|
'cmake_path': 'cmake',
|
|
|
|
'num_cores': 2,
|
2024-11-22 14:25:19 +01:00
|
|
|
'launcher': 'iprbench.unittest',
|
2024-11-17 11:31:48 +01:00
|
|
|
}
|
|
|
|
test_benchmark(benchmark_id, benchmark_config, self.results_root_dir)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
unittest.main()
|