-
Notifications
You must be signed in to change notification settings - Fork 38
/
test_ScalarWave.py
68 lines (40 loc) · 1.8 KB
/
test_ScalarWave.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
57
58
59
60
61
62
63
64
65
66
67
68
from UnitTesting.create_test import create_test
def test_InitialData_PlaneWave():
module = 'ScalarWave.InitialData'
module_name = 'InitialData'
function_and_global_dict = {'InitialData(Type="PlaneWave")': ['uu_ID', 'vv_ID']}
create_test(module, module_name, function_and_global_dict)
def test_InitialData_SphericalGaussian():
module = 'ScalarWave.InitialData'
module_name = 'InitialData'
function_and_global_dict = {'InitialData(Type="SphericalGaussian")': ['uu_ID', 'vv_ID']}
create_test(module, module_name, function_and_global_dict)
def test_ScalarWave_RHSs():
module = 'ScalarWave.ScalarWave_RHSs'
module_name = 'ScalarWave_RHSs'
function_and_global_dict = {'ScalarWave_RHSs()': ['wavespeed', 'uu_rhs', 'vv_rhs']}
create_test(module, module_name, function_and_global_dict)
def test_ScalarWaveCurvilinear_RHSs():
module = 'ScalarWave.ScalarWaveCurvilinear_RHSs'
module_name = 'ScalarWaveCurvilinear_RHSs'
function_and_global_dict = {'ScalarWaveCurvilinear_RHSs()': ['uu_rhs', 'vv_rhs']}
create_test(module, module_name, function_and_global_dict)
if __name__ == '__main__':
import sys
if len(sys.argv) <= 3:
failed_functions = []
for fun in dir():
if fun[0:5] == 'test_':
print('\nTesting ' + str(fun) + '...\n')
try:
exec(fun + '()')
except SystemExit:
failed_functions.append(fun)
if failed_functions != []:
import sys, os
with open(os.path.join('UnitTesting', 'failed_tests.txt'), 'a') as file:
for function in failed_functions:
file.write(sys.argv[0] + ': ' + str(function) + '\n')
sys.exit(1)
else:
globals()[sys.argv[4]]()