2024-11-17 11:31:48 +01:00
|
|
|
"""tests all IResultsDb implementations
|
|
|
|
"""
|
|
|
|
import unittest
|
|
|
|
import logging
|
|
|
|
import subprocess
|
|
|
|
import json
|
|
|
|
from pathlib import Path
|
|
|
|
from iprbench.core import ResultsDbParams
|
|
|
|
from shutil import rmtree
|
|
|
|
from cocluto.SimpaDbUtil import SshAccessedMysqlDb
|
|
|
|
|
|
|
|
|
|
|
|
def test_resultsdb(resultsdb_params: ResultsDbParams, results_root_path: Path):
|
|
|
|
results_db_type = resultsdb_params['type']
|
|
|
|
logging.info('testing resultsdb %s', results_db_type)
|
|
|
|
logging.info('resultsdb_params : %s', json.dumps(resultsdb_params))
|
|
|
|
results_dir = results_root_path / results_db_type
|
|
|
|
if results_dir.exists():
|
|
|
|
rmtree(results_dir)
|
|
|
|
results_dir.mkdir(parents=True)
|
|
|
|
benchmark_id = 'mamul1'
|
|
|
|
benchmark_config = {
|
2024-11-19 21:37:55 +01:00
|
|
|
'fortran_compiler': 'gfortran:<default>',
|
2024-11-21 08:29:45 +01:00
|
|
|
'blas_library': '<default-libblas>:<default>',
|
2024-11-17 11:31:48 +01:00
|
|
|
'matrix_size': 1024,
|
|
|
|
'num_loops': 10,
|
|
|
|
'num_cores': 2
|
|
|
|
}
|
|
|
|
command = f'iprbench-run --benchmark-id \'{benchmark_id}\' --config \'{json.dumps(benchmark_config)}\' --results-dir {results_dir} --resultsdb-params \'{json.dumps(resultsdb_params)}\''
|
|
|
|
subprocess.run(command, shell=True, check=True, executable='/bin/bash')
|
|
|
|
|
|
|
|
|
|
|
|
class ResultsDbTestCase(unittest.TestCase):
|
|
|
|
|
|
|
|
results_root_dir: Path
|
|
|
|
|
|
|
|
def setUp(self) -> None: # pylint: disable=useless-parent-delegation
|
|
|
|
self.results_root_dir = Path('/tmp/iprbenchs/test_results/resultsdb')
|
|
|
|
if self.results_root_dir.exists():
|
|
|
|
rmtree(self.results_root_dir)
|
|
|
|
self.results_root_dir.mkdir(parents=True)
|
|
|
|
return super().setUp()
|
|
|
|
|
|
|
|
def test_tsvfiles(self):
|
|
|
|
resultsdb_params = {
|
|
|
|
'type': 'tsv-files',
|
|
|
|
'tsv_results_dir': str(self.results_root_dir / 'tsv-files')
|
|
|
|
}
|
|
|
|
test_resultsdb(resultsdb_params, self.results_root_dir)
|
|
|
|
|
|
|
|
def test_sqlitedatabase(self):
|
|
|
|
resultsdb_params = {
|
|
|
|
'type': 'sqlite-database',
|
|
|
|
'sqlite_file_path': str(self.results_root_dir / 'sqlite-database/results.sqlite')
|
|
|
|
}
|
|
|
|
test_resultsdb(resultsdb_params, self.results_root_dir)
|
|
|
|
|
|
|
|
def test_sqlserver(self):
|
|
|
|
db_server_fqdn = 'iprbenchsdb.ipr.univ-rennes1.fr'
|
|
|
|
db_user = 'test_iprbenchw'
|
|
|
|
db_name = 'test_iprbenchs'
|
|
|
|
ssh_user = 'test_iprbenchw'
|
|
|
|
sql_backend = SshAccessedMysqlDb(db_server_fqdn, db_user, db_name, ssh_user)
|
|
|
|
if sql_backend.table_exists('mamul1'):
|
|
|
|
sql_backend.delete_table('mamul1')
|
|
|
|
resultsdb_params = {
|
|
|
|
'type': 'sqlserver-viassh-database',
|
|
|
|
'db_server_fqdn': db_server_fqdn,
|
|
|
|
'db_user': db_user,
|
|
|
|
'db_name': db_name,
|
|
|
|
'ssh_user': ssh_user
|
|
|
|
}
|
|
|
|
test_resultsdb(resultsdb_params, self.results_root_dir)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
unittest.main()
|