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 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
/*
* Copyright (c) 2017, Miroslav Stoyanov
*
* This file is part of
* Toolkit for Adaptive Stochastic Modeling And Non-Intrusive ApproximatioN: TASMANIAN
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions
* and the following disclaimer in the documentation and/or other materials provided with the distribution.
*
* 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse
* or promote products derived from this software without specific prior written permission.
*
* 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 HOLDER 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.
*
* UT-BATTELLE, LLC AND THE UNITED STATES GOVERNMENT MAKE NO REPRESENTATIONS AND DISCLAIM ALL WARRANTIES, BOTH EXPRESSED AND IMPLIED.
* THERE ARE NO EXPRESS OR IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, OR THAT THE USE OF THE SOFTWARE WILL NOT INFRINGE ANY PATENT,
* COPYRIGHT, TRADEMARK, OR OTHER PROPRIETARY RIGHTS, OR THAT THE SOFTWARE WILL ACCOMPLISH THE INTENDED RESULTS OR THAT THE SOFTWARE OR ITS USE WILL NOT RESULT IN INJURY OR DAMAGE.
* THE USER ASSUMES RESPONSIBILITY FOR ALL LIABILITIES, PENALTIES, FINES, CLAIMS, CAUSES OF ACTION, AND COSTS AND EXPENSES, CAUSED BY, RESULTING FROM OR ARISING OUT OF,
* IN WHOLE OR IN PART THE USE, STORAGE OR DISPOSAL OF THE SOFTWARE.
*/
#include "testConstructSurrogate.hpp"
#include "testLoadUnstructured.hpp"
#include "testExoticQuadrature.hpp"
#include "testCustomTabulated.hpp"
void debugTest() {
cout << "Debug Test (callable from the CMake build folder)" << endl;
cout << "Put testing code here and call with ./Addons/addontester debug" << endl;
}
int main(int argc, char const **argv){
std::deque<std::string> args = stringArgs(argc, argv);
bool debug = false;
bool pass_all = true;
bool verbose = false;
int gpuid = -1;
while(not args.empty()){
if (args.front() == "debug") debug = true;
if (hasInfo(args.front())) verbose = true;
if (hasGpuID(args.front())){
args.pop_front();
gpuid = getGpuID(args);
}
args.pop_front();
}
if (debug){
debugTest();
return 0;
}
cout << "\n\n";
cout << "---------------------------------------------------------------------" << endl;
cout << " Tasmanian Addons Module: Functionality Test" << endl;
cout << "---------------------------------------------------------------------" << endl << endl;
bool pass = testConstructSurrogate(verbose);
cout << std::setw(40) << "Automated construction" << std::setw(10) << ((pass) ? "Pass" : "FAIL") << endl;
pass_all = pass_all && pass;
#if defined(Tasmanian_ENABLE_BLAS) || defined(Tasmanian_ENABLE_GPU)
pass = true;
pass = testLoadUnstructuredL2(verbose, gpuid);
cout << std::setw(40) << "Unstructured construction" << std::setw(10) << ((pass) ? "Pass" : "FAIL") << endl;
pass_all = pass_all && pass;
#else
cout << std::setw(40) << "Unstructured construction" << std::setw(10) << "skipping" << endl;
gpuid *= 2; // no op to register the use of gpuid
#endif
// Tests for Exotic Quadrature.
pass = true;
pass = testExoticQuadrature();
cout << std::setw(40) << "Exotic quadrature" << std::setw(10) << ((pass) ? "Pass" : "FAIL") << endl;
pass_all = pass_all && pass;
// Tests for manipulating CustomTabulated objects.
pass = true;
pass = testCustomTabulated();
cout << std::setw(40) << "CustomTabulated manipulation" << std::setw(10) << ((pass) ? "Pass" : "FAIL") << endl;
pass_all = pass_all && pass;
cout << "\n";
if (pass){
cout << "---------------------------------------------------------------------" << endl;
cout << " All Tests Completed Successfully" << endl;
cout << "---------------------------------------------------------------------" << endl << endl;
}else{
cout << "FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL" << endl;
cout << " Some Tests Have Failed" << endl;
cout << "FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL FAIL" << endl << endl;
}
return ((pass_all) ? 0 : 1);
}
|