-
Notifications
You must be signed in to change notification settings - Fork 248
/
Copy pathco_simulation_test_case.py
56 lines (38 loc) · 1.91 KB
/
co_simulation_test_case.py
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
import KratosMultiphysics as KM
import KratosMultiphysics.KratosUnittest as KratosUnittest
import KratosMultiphysics.kratos_utilities as kratos_utils
from KratosMultiphysics.CoSimulationApplication.co_simulation_analysis import CoSimulationAnalysis
import os, subprocess
class CoSimulationTestCase(KratosUnittest.TestCase):
'''This class is the basis for the testing the framework
It can be used to test complete cases with the "CoSimulation-Analysis"
'''
def _createTest(self, problem_dir_name, parameter_file_name):
self.problem_dir_name = problem_dir_name
full_parameter_file_name = os.path.join(problem_dir_name, parameter_file_name + '_parameters.json')
with open(full_parameter_file_name, 'r') as parameter_file:
self.cosim_parameters = KM.Parameters(parameter_file.read())
# To avoid many prints
echo_level = self.cosim_parameters["problem_data"]["echo_level"].GetInt()
if (echo_level == 0):
KM.Logger.GetDefaultOutput().SetSeverity(KM.Logger.Severity.WARNING)
else:
KM.Logger.GetDefaultOutput().SetSeverity(KM.Logger.Severity.INFO)
self.addCleanup(kratos_utils.DeleteTimeFiles, self.problem_dir_name)
def _runTest(self):
CoSimulationAnalysis(self.cosim_parameters).Run()
def _runTestWithExternal(self, subprocess_args_list):
self.addCleanup(self.__TerminateSubProcessIfRunning)
self.p = subprocess.Popen(subprocess_args_list)
CoSimulationAnalysis(self.cosim_parameters).Run()
self.p.communicate()
self.assertEqual(self.p.returncode, 0)
def __TerminateSubProcessIfRunning(self):
poll = self.p.poll()
if poll == None:
self.p.terminate()
# called only once for this class, opposed of tearDown()
@classmethod
def tearDownClass(cls):
# Cleaning
kratos_utils.DeleteDirectoryIfExisting("__pycache__")