Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unit test 150 #198

Merged
merged 25 commits into from
Mar 14, 2024
Merged
Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
ff7c378
test.cpp is a unitTest file for getpk2cc() without GoogleTest
Feb 1, 2024
c452049
implement GTest, individually work well, not good with test.cpp
Feb 2, 2024
3dec73a
all works! next: abs path in CMakeLists, test.cpp, unitTest.xml
Feb 2, 2024
d6c5775
Merge branch 'SimVascular:main' into unit_test_150
yuecheng-yu Feb 5, 2024
a9e87c8
current_path different between compilation(GTest) and real runtime(exe)
Feb 6, 2024
c34b201
GTest: exe at build/svFSI-build/Source/svFSI, source at tests/unitTests
Feb 16, 2024
dfe18c3
cleaned CMakeLists and test.cpp
Feb 21, 2024
cae5712
Merge branch 'main' into unit_test_150
Feb 21, 2024
6c7b5f3
modified .github/workflow/test
Feb 22, 2024
279ee52
add copyright, changed file_path in test.cpp
Feb 22, 2024
768a920
update workflow, add copyright
Feb 22, 2024
1083630
revise cmakelist to disable gtest_discover_tests
Feb 23, 2024
beab321
link pthread for ubuntu20, link LAPACK for ubuntu22
Feb 23, 2024
ba6eeb9
try to link threads lib for ubuntu20
Feb 23, 2024
9a066e6
try to link pthread on ubuntu20
Feb 23, 2024
d5a8347
2nd try to link pthread on ubuntu20
Feb 26, 2024
b8138d5
last try to link pthread on ubuntu20
Feb 26, 2024
dfeb900
last after the last try to link pthread on ubuntu20
Feb 26, 2024
57014fa
use test fixture, same setup for multiple tests
Mar 1, 2024
c986d3f
At the mid of nowhere for GMock, stuck in ten_dyad_prod()
Mar 5, 2024
47c0e18
gmock works, note: initialize mat_fun_carray::ten_init(3) before
Mar 6, 2024
c912637
create a class for isotropic material unit test (only support C10, C01)
Mar 12, 2024
c5d0b31
some clean up
Mar 13, 2024
a1a6f91
add --verbose
Mar 13, 2024
2bf104c
initialize static arrays with {}
Mar 13, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ jobs:
run: |
mkdir build
cd build
cmake -DENABLE_COVERAGE=ON -DENABLE_ARRAY_INDEX_CHECKING=ON ..
cmake -DENABLE_COVERAGE=ON -DENABLE_ARRAY_INDEX_CHECKING=ON -DENABLE_UNIT_TEST=ON ..
make -j2
- name: Install test dependencies
run: |
Expand All @@ -39,6 +39,10 @@ jobs:
git lfs pull
cd tests
conda run -n svfsiplus pytest -rPv --durations=0
- name: Run unit tests
run: |
cd build/svFSI-build/Source/svFSI
ctest --output-on-failure
- name: Generate code coverage
if: startsWith(matrix.os, 'ubuntu-22.04')
run: |
Expand Down
2 changes: 2 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,7 @@ set(SV_PETSC_DIR "" CACHE STRING "Path to a local install of the PETSc linear al
set(ENABLE_COVERAGE OFF CACHE BOOL "Enable code coverage")
set(ENABLE_ARRAY_INDEX_CHECKING OFF CACHE BOOL "Enable Array index checking")
set(SV_LOCAL_VTK_PATH "" CACHE STRING "Path to a local build of VTK.")
set(ENABLE_UNIT_TEST OFF CACHE BOOL "Enable Unit Test by Google Test")

#-----------------------------------------------------------------------------
# RPATH handling
Expand Down Expand Up @@ -147,6 +148,7 @@ ExternalProject_Add(svFSI
#-DSV_USE_PETSC:BOOL=${SV_USE_PETSC}
-DSV_PETSC_DIR:STRING=${SV_PETSC_DIR}
-DENABLE_COVERAGE:BOOL=${ENABLE_COVERAGE}
-DENABLE_UNIT_TEST:BOOL=${ENABLE_UNIT_TEST}
-DENABLE_ARRAY_INDEX_CHECKING:BOOL=${ENABLE_ARRAY_INDEX_CHECKING}
-DSV_LOCAL_VTK_PATH:STRING=${SV_LOCAL_VTK_PATH}
${SV_APPLE_CMAKE_ARGS}
Expand Down
52 changes: 52 additions & 0 deletions Code/Source/svFSI/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -260,4 +260,56 @@ if(ENABLE_COVERAGE)
WORKING_DIRECTORY ${CMAKE_BINARY_DIR})
endif()

# unit tests and Google Test
if(ENABLE_UNIT_TEST)

# link pthread on ubuntu20
find_package(Threads REQUIRED)

# install Google Test
include(FetchContent)
FetchContent_Declare(
googletest
URL https://github.com/google/googletest/archive/03597a01ee50ed33e9dfd640b249b4be3799d395.zip
)
FetchContent_MakeAvailable(googletest)
enable_testing()
include(GoogleTest)

# add test.cpp for unit test

# remove the main.cpp and add test.cpp
list(APPEND CSRCS "../../../tests/unitTests/test.cpp")
list(REMOVE_ITEM CSRCS "main.cpp")

# include source files (same as what svFSI does except for main.cpp)
add_executable(run_all_unit_tests ${CSRCS})

# libraries
target_link_libraries(run_all_unit_tests
${GLOBAL_LIBRARIES}
${INTELRUNTIME_LIBRARIES}
${ZLIB_LIBRARY}
${BLAS_LIBRARIES}
${LAPACK_LIBRARIES}
${METIS_SVFSI_LIBRARY_NAME}
${PARMETIS_SVFSI_LIBRARY_NAME}
${TETGEN_LIBRARY_NAME}
${TINYXML_LIBRARY_NAME}
${SV_LIB_SVFSILS_NAME}${SV_MPI_NAME_EXT}
${VTK_LIBRARIES}
)

# link Google Test
target_link_libraries(
run_all_unit_tests
gtest
GTest::gtest_main
pthread # link pthread on ubuntu20
)

# gtest_discover_tests(runUnitTest)
add_test(NAME UnitTest COMMAND run_all_unit_tests)

endif()

27 changes: 27 additions & 0 deletions Code/Source/svFSI/mat_models.cpp
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -214,6 +214,8 @@ void get_pk2cc(const ComMod& com_mod, const CepMod& cep_mod, const dmnType& lDmn
//
Tensor4<double> CC(nsd,nsd,nsd,nsd);

std::cout << "test brreak point *1" << std::endl;

switch (stM.isoType) {
case ConstitutiveModelType::stIso_lin: {
double g1 = stM.C10; // mu
Expand Down Expand Up @@ -242,23 +244,48 @@ void get_pk2cc(const ComMod& com_mod, const CepMod& cep_mod, const dmnType& lDmn

// NeoHookean model
case ConstitutiveModelType::stIso_nHook: {
std::cout << "test brreak point *2" << std::endl;

double g1 = 2.0 * stM.C10;
auto Sb = g1*Idm;

// Fiber reinforcement/active stress
Sb += Tfa * mat_dyad_prod(fl.col(0), fl.col(0), nsd);

std::cout << "test brreak point *3" << std::endl;

double r1 = g1 * Inv1 / nd;
for (int j = 0; j < S.ncols(); j++) {
for (int i = 0; i < S.nrows(); i++) {
S(i,j) = J2d*Sb(i,j) - r1*Ci(i,j);
}
}

std::cout << "test brreak point *4" << std::endl;
std::cout << "nd, nsd: " << nd << ", "<< nsd << std::endl;
S.print("S: ");
Ci.print("Ci: ");


Array<double> A(3, 3);
Array<double> B = mat_fun::mat_id(3);
A.print("this is A: ");
B.print("this is B: ");
Tensor4<double> ret = ten_dyad_prod(A, B, 3);
std::cout << "test brreak point *4" << std::endl;


ten_dyad_prod(B, A, 3);
std::cout << "test brreak point *4" << std::endl;

CC = (-2.0/nd) * ( ten_dyad_prod(Ci, S, nsd) + ten_dyad_prod(S, Ci, nsd));
std::cout << "test brreak point *5" << std::endl;
S += p*J*Ci;
std::cout << "test brreak point *6" << std::endl;
CC += 2.0*(r1 - p*J) * ten_symm_prod(Ci, Ci, nsd) + (pl*J - 2.0*r1/nd) * ten_dyad_prod(Ci, Ci, nsd);

std::cout << "test brreak point *7" << std::endl;

} break;

// Mooney-Rivlin model
Expand Down
3 changes: 3 additions & 0 deletions tests/unitTests/mesh/unit_cube_volume.vtu
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved
Git LFS file not shown
94 changes: 94 additions & 0 deletions tests/unitTests/test.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
/* Copyright (c) Stanford University, The Regents of the University of California, and others.
*
* All Rights Reserved.
*
* See Copyright-SimVascular.txt for additional details.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject
* to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

#include "test.h"

using namespace mat_fun;
using namespace std;


TEST(UnitTest, nHK) {
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved
// Step 1: define parameters
auto matType = consts::ConstitutiveModelType::stIso_nHook; // Material_model: options refer to consts.h
auto volType = consts::ConstitutiveModelType::stVol_ST91; // Dilational_penalty_model
double E = 1e6; // Elasticity_modulus
double nu = 0.5; // Poisson_ratio
double pen = 4e9; // Penalty_parameter
double C01; // additional parameter to C10 (optional)

// Step 2: construct test object
UnitTestIso nHK(matType, E, nu, volType, pen, C01);

// Step 3: define the input
double F[3][3];
memset(F, 0, sizeof(F)); // initialize
mrp089 marked this conversation as resolved.
Show resolved Hide resolved
F[0][0] = 1.0; F[1][1] = 1.0; F[2][2] = 1.0; // set to Identity

// Step 4: define the reference output
double S_ref[3][3], Dm_ref[6][6];
mrp089 marked this conversation as resolved.
Show resolved Hide resolved
memset(S_ref, 0, sizeof(S_ref));
memset(Dm_ref, 0, sizeof(Dm_ref));

// Step 5: run unit test
nHK.runUnitTest(F, S_ref, Dm_ref);

}

TEST(UnitTest, MR) {
mrp089 marked this conversation as resolved.
Show resolved Hide resolved
// Step 1: define parameters
auto matType = consts::ConstitutiveModelType::stIso_MR; // Material_model: options refer to consts.h
auto volType = consts::ConstitutiveModelType::stVol_ST91; // Dilational_penalty_model
double E = 1e6; // Elasticity_modulus
double nu = 0.495; // Poisson_ratio
double pen = 4e9; // Penalty_parameter
double C01 = 0.1; // additional parameter to C10 (optional)

// Step 2: construct test object
UnitTestIso MR(matType, E, nu, volType, pen, C01);

// Step 3: define the input
double F[3][3];
memset(F, 0, sizeof(F)); // initialize
F[0][0] = 1.0; F[1][1] = 1.0; F[2][2] = 1.0; // set to Identity

// Step 4: define the reference output
double S_ref[3][3], Dm_ref[6][6];
memset(S_ref, 0, sizeof(S_ref));
memset(Dm_ref, 0, sizeof(Dm_ref));

// Step 5: run unit test
MR.runUnitTest(F, S_ref, Dm_ref);

}

// int main(int argc, char **argv) {
// ::testing::InitGoogleTest(&argc, argv);
// return RUN_ALL_TESTS();
// }
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved
129 changes: 129 additions & 0 deletions tests/unitTests/test.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
/* Copyright (c) Stanford University, The Regents of the University of California, and others.
*
* All Rights Reserved.
*
* See Copyright-SimVascular.txt for additional details.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject
* to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

#include <stdlib.h>
#include <iostream>
#include "gtest/gtest.h" // include GoogleTest
#include "mat_fun.h"
#include "mat_fun_carray.h"
#include "mat_models.h"
#include "mat_models_carray.h"





class MockCepMod : public CepMod {
public:
MockCepMod() {
// initialize if needed
}
// Mock methods if needed
};
class MockdmnType : public dmnType {

Check warning on line 50 in tests/unitTests/test.h

View check run for this annotation

Codecov / codecov/patch

tests/unitTests/test.h#L50

Added line #L50 was not covered by tests
public:
MockdmnType() {
// initialize if needed
}
// MockstModelType mockStM;
// Mock methods if needed
};
class MockmshType : public mshType {
public:
MockmshType() {
// initialize if needed
}
// Mock methods if needed
};
class MockeqType : public eqType {

Check warning on line 65 in tests/unitTests/test.h

View check run for this annotation

Codecov / codecov/patch

tests/unitTests/test.h#L65

Added line #L65 was not covered by tests
public:
MockeqType() {
// initialize if needed
}
MockdmnType mockDmn;
// Mock methods if needed
};
class MockComMod : public ComMod {
public:
MockComMod() {
// initialize if needed
nsd = 3;
}
MockeqType mockEq;
MockmshType mockMsh;
// Mock methods if needed
};


class UnitTestIso {
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved
public:
MockComMod com_mod;
MockCepMod cep_mod;

// UnitTestIso(consts::ConstitutiveModelType matType, double E, double nu,
// consts::ConstitutiveModelType penType, double pen)
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved
UnitTestIso(consts::ConstitutiveModelType matType, double E, double nu,
consts::ConstitutiveModelType penType, double pen, double C01 = 0.0) {
int nsd = com_mod.nsd;
auto &dmn = com_mod.mockEq.mockDmn;
mat_fun_carray::ten_init(nsd); // initialize tensor index pointer
dmn.stM.isoType = matType; // Mat_model
double mu = 0.5 * E / (1.0 + nu); // Shear_modulus
dmn.stM.C10 = 0.5 * mu - C01; // set_material_props.h
dmn.stM.C01 = C01;
dmn.stM.volType = penType; // Dilational_penalty_model
dmn.stM.Kpen = pen; // Penalty_parameter
}

void runUnitTest(double F[3][3], double S_ref[3][3], double Dm_ref[6][6]) {
int nsd = com_mod.nsd;
auto &dmn = com_mod.mockEq.mockDmn;
// hard code for nHK
int nFn = 1;
Array<double> fN(nsd, nFn);
double ya_g = 0.0;
double S[3][3], Dm[6][6];
// memset(S, 0, sizeof(S));
// memset(Dm, 0, sizeof(Dm));
yuecheng-yu marked this conversation as resolved.
Show resolved Hide resolved

mat_models_carray::get_pk2cc(com_mod, cep_mod, dmn, F, nFn, fN, ya_g, S, Dm);
double tol = 1e-12; // tolerance

for (int i = 0; i < 3; i++){
for (int j = 0; j < 3; j++){
EXPECT_NEAR(S[i][j], S_ref[i][j], tol);
}
}


}


};
Loading
Loading