UCVM Testing
Contents
- 1 UCVM C-Language Testing Fixtures
- 2 UCVM Python Language Testing
- 3 UCVM Test Scripts
- 4 Manifest of UCVM Programs and Scripts Requiring Tests
- 5 Programs in UCVM Source Distribution
- 6 Core UCVM C-language tests - Unittests
- 7 Core Capabilities Requiring Tests
- 8 Programs Requiring Integration Tests
- 9 Model Tests
- 10 Utilities Tests
- 11 Acceptance tests
- 12 Related Entries
UCVM C-Language Testing Fixtures
- C-Language - unittest - C executable
- accepttest - C executable
UCVM uses two C language programs called unittest.c and accepttest.c framework. These C program framework provides methods like "test_assert_string()". There are references to an xmldir with list of tests, but that is not used. These C language tests enable us to test the C-API for UCVM
Test defined as C lanuage functions in accepttest_suite_grid.c
- test_grid_tool_1d()
- test_grid_lib_1d()
- then suite_xxx() where test_grid_tool_1d is tested with its own script
UCVM Python Language Testing
UCVM uses a custom script accept_test.py. Contains two tests:
- def test_vs30_query(dir)
- def test_ssh_generate(dir):
UCVM Test Scripts
- make check - defined in ucvm_bin/tests
- runs unittest
- runs accepttest
- runs accept_test.py
- Makefile.am creates script > run-testing
- unittest
- accepttest
- accept_test.py
- cd api; ./run_query_1d_gtl.sh
- cd basin; ./run_basin_query_mpi_cvms5.sh
- cd mesh; ./run_ucvm2mesh_mpi_layer_cvms.sh
Manifest of UCVM Programs and Scripts Requiring Tests
Programs in UCVM bin directory:
- ssh_generate
- ssh_merge
- vs30_query
- vs30_query_mpi
- basin_query
- basin_query_mpi
- basin_query_mpi_complete
- ecoalesce
- ecompact
- grd2etree
- grd_query
- mesh_check
- mesh_op
- mesh_strip_ijk
- patchmodel
- ucvm2mesh
- ucvm2mesh_mpi
- ucvm2mesh_mpi_layer
- ucvm2etree
- ucvm2etree_extract_MPI
- ucvm2etree_merge_MPI
- ucvm2etree_sort_MPI
- ucvm_query
Programs in Utilities Directory:
- installed_models.py
- makegrid.sh
- run_ucvm_query.sh
- run_ucvm.sh
- time_mesh_generation.py
- view_png.py
Test programs:
- unittest
- accepttest
- accept_test.py
- api/query_1d_gtl
- api/run_query_1d_gtl.sh
- basin/run_basin_query_mpi_cvms5.sh -> tests basin_query_mpi
- mesh/ucvm2mesh_mpi_layer
- mesh/run_ucvm2mesh_mpi_layer_cvms.sh
Programs in UCVM Source Distribution
The programs listed above are found in the ucvm_bin/ installation directory. The UCVM installation process includes a source code directory with numerous example programs not included in the bin installation. A list of programs in the UCVM Source directory is given here:
UCVM Plotting routines have been moved into a separate repo. Information on the plotting routines.
Core UCVM C-language tests - Unittests
Tests for adding Models to UCVM. These also confirm path to UCVM models set correctly. Test defined as c language functions in unittest_suite_lib.c. This c-language program imports ucvm.h and then calls the UCVM API from C language program. The inputs and expected results for several of the tests are hard-coded in the C source code files.
- test_lib_init()
- test_lib_add_model_1d()
- test_lib_query_1d()
- test_lib_get_model_label_1d()
- test_lib_setparam_querymode_gd_1d()
- test_lib_setparam_querymode_ge_1d
- test_lib_model_version_1d
Following Tests have conditional compile statements in unittest.c
- test_lib_add_model_cencal
- test_lib_add_model_cvmh
- test_lib_add_model_cvms
- test_lib_add_model_cvmsi
- test_lib_add_model_ivlsu
- test_lib_add_model_cvlsu
- test_lib_add_model_albacore
- test_lib_add_model_cvms5
- test_lib_add_model_cca
- test_lib_add_model_cs173
- test_lib_add_model_cs173h
Tests for Query by Elevation/Query by Depth
- int test_lib_setparam_querymode_gd_1d()
- int test_lib_setparam_querymode_ge_1d()
Core Capabilities Requiring Tests
Additional Key Core Functionality
- Test case interpolation
- Test Cases Tiling
- Test Cases Invalid Point
Tests for C executables of basic query interface
- ucvm_query
- basin_query
Programs Requiring Integration Tests
Meshing Commands and scripts - Referenced but not found
- run_grd.sh
- test_grid
- test_ucvm
- ehelper
- grd
- vs30_query_debug
- work/make_manifest.py
These tests need to be migrated to unittest_suite_lib.c
- Adding Elygtl:ifunc
- accepttest_suite_grid.c:int test_grid_tool_1d()
- accepttest_suite_grid.c:int test_grid_lib_1d()
These tests need to be migrated to standard python test framework
- accept_test.py:def test_vs30_query(dir):
- accept_test.py:def test_ssh_generate(dir):
Model Tests
Each velocity model has tests showing expected results for some points
- Test Cases 1D Models
- Test Cases CVM S4.26
- Test Cases CVM-H
- Test Cases External CVMs
- Test Cases Invalid Points
Utilities Tests
In Utilities Directory:
- run_ucvm.sh
- installed_models.py
- makegrid.sh
- run_ucvm.sh
- run_ucvm_query.sh
- time_mesh_generator.py
- view_png.py
Additional Utility Tests
- /api/run_query_1d_gtl.sh
- programs/basin/run_basin_query_cvmh.sh
- programs/basin/run_basin_query_mpi_complete_cencal_cvms.sh
- programs/basin/run_basin_query_mpi_complete_cencal_cvms5.sh
- programs/basin/run_basin_query_mpi_complete_cencal_cvmsi.sh
- programs/basin/run_basin_query_mpi_cvms5.sh
- programs/etree/run_ucvm2etree_cvmh.sh
- programs/mesh/run_ucvm2mesh_cvmh.sh
- programs/mesh/run_ucvm2mesh_mpi_cvmh.sh
- programs/mesh/run_ucvm2mesh_mpi_cvmsi.sh
- programs/mesh/run_ucvm2mesh_mpi_layer_cvms.sh
- programs/mesh/run_ucvm2mesh_mpi_layer_cvmsi.sh
- programs/ucvm/run_ucvm_query_albacore.sh
- programs/ucvm/run_ucvm_query_cencal_cvms.sh
- programs/ucvm/run_ucvm_query_cencal_cvms5.sh
- programs/ucvm/run_ucvm_query_cvmh.sh
- programs/ucvm/run_ucvm_query_wfcvm.sh
Acceptance tests
Confirm results on users system. Maybe union of funcational, integration, and model tests.