/* This file is part of MAUS: http://micewww.pp.rl.ac.uk/projects/maus * * MAUS is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * MAUS is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with MAUS. If not, see . * */ #include #include #include #include "gtest/gtest.h" #include "json/value.h" #include "src/common_cpp/Utils/JsonWrapper.hh" #include "src/common_cpp/Globals/GlobalsManager.hh" extern char *optarg; // return value is verbose_level, if we change the flags we will need to change // the call structure slightly... int parse_flags(int argc, char **argv) { int _verbose_level = 1; int _help = 2; option long_options[] = { {"verbose_level", required_argument, NULL, _verbose_level}, {"help", no_argument, NULL, _help}, {NULL, 0, NULL, 0} }; int option = 0; int option_index = 0; while (option != -1) { option = getopt_long_only(argc, argv, "", long_options, &option_index); if (option == _verbose_level) { std::stringstream ss(optarg); int verbose_level = 2; ss >> verbose_level; return verbose_level; } else if (option == _help) { std::cerr << "\n\nThis test program takes MAUS defined options:\n" << " --verbose_level=(integer)\n" << " verbose level for MAUS IO\n" << std::endl; }// else probably a gtest flag, so ignore } return 2; } Json::Value SetupConfig(int verbose_level) { std::cerr << "Running with verbose level " << verbose_level << std::endl; Json::Value config(Json::objectValue); config["maximum_module_depth"] = 50; config["check_volume_overlaps"] = true; config["reconstruction_geometry_filename"] = "Test.dat"; config["simulation_geometry_filename"] = "Test.dat"; config["simulation_geometry_debug"] = false; config["maximum_number_of_steps"] = 10000; config["will_do_stack_trace"] = true; config["keep_tracks"] = true; config["keep_steps"] = true; config["verbose_level"] = verbose_level; config["geant4_visualisation"] = false; config["physics_model"] = "QGSP_BERT"; config["reference_physics_processes"] = "mean_energy_loss"; config["physics_processes"] = "standard"; config["particle_decay"] = true; config["polarised_decay"] = true; config["charged_pion_half_life"] = -1.; config["muon_half_life"] = -1.; config["production_threshold"] = 0.5; config["fine_grained_production_threshold"] = Json::Value(Json::objectValue); config["default_keep_or_kill"] = true; config["spin_tracking"] = true; config["keep_or_kill_particles"] = "{\"neutron\":False}"; config["kinetic_energy_threshold"] = 0.1; config["max_step_length"] = 100.; config["max_track_time"] = 1.e9; config["max_track_length"] = 1.e8; config["simulation_reference_particle"] = JsonWrapper::StringToJson( std::string("{\"position\":{\"x\":0.0,\"y\":-0.0,\"z\":-5500.0},")+ std::string("\"spin\":{\"x\":0.0,\"y\":-0.0,\"z\":1.0},")+ std::string("\"momentum\":{\"x\":0.0,\"y\":0.0,\"z\":1.0},")+ std::string("\"particle_id\":-13,\"energy\":226.0,\"time\":0.0,")+ std::string("\"random_seed\":10}") ); config["stepping_algorithm"] = "ClassicalRK4"; config["delta_one_step"] = -1.; config["delta_intersection"] = -1.; config["epsilon_min"] = -1.; config["epsilon_max"] = -1.; config["miss_distance"] = -1.; config["everything_special_virtual"] = false; config["field_tracker_absolute_error"] = 1.e-4; config["field_tracker_relative_error"] = 1.e-4; return config; } int main(int argc, char **argv) { int test_out = -1; try { std::cout << "Initialising Globals" << std::endl; int verbose_level = parse_flags(argc, argv); MAUS::GlobalsManager::InitialiseGlobals( JsonWrapper::JsonToString(SetupConfig(verbose_level)) ); ::testing::InitGoogleTest(&argc, argv); std::cout << "Running tests" << std::endl; test_out = RUN_ALL_TESTS(); } catch (MAUS::Exception exc) { std::cerr << exc.GetMessage() << "\n" << exc.GetLocation() << "\n" << exc.GetStackTrace() << std::endl; } catch (std::exception exc) { std::cerr << "Caught std::exception" << "\n" << exc.what() << std::endl; } MAUS::GlobalsManager::Finally(); return test_out; }