reworkes test infrastructure and tests
This commit is contained in:
		| @@ -1,13 +1,9 @@ | ||||
| cmake_minimum_required(VERSION 3.12) | ||||
| find_package(Boost COMPONENTS program_options REQUIRED) | ||||
| add_executable (ordered_sem  | ||||
|     sc_main.cpp | ||||
| ) | ||||
| target_link_libraries (ordered_sem LINK_PUBLIC scc) | ||||
| if(TARGET Boost::program_options) | ||||
| 	target_link_libraries(ordered_sem PUBLIC Boost::program_options) | ||||
| else() | ||||
| 	target_link_libraries(ordered_sem LINK_PUBLIC ${BOOST_program_options_LIBRARY}) | ||||
| endif() | ||||
| project (ordered_semaphore) | ||||
|  | ||||
| add_test(NAME ordered_sem_test COMMAND ordered_sem) | ||||
| add_executable(${PROJECT_NAME}  | ||||
| 	test.cpp | ||||
| 	${test_util_SOURCE_DIR}/sc_main.cpp | ||||
| ) | ||||
| target_link_libraries (${PROJECT_NAME} PUBLIC test_util) | ||||
|  | ||||
| add_test(NAME ${PROJECT_NAME} COMMAND ${PROJECT_NAME}) | ||||
|   | ||||
| @@ -1,110 +0,0 @@ | ||||
| //////////////////////////////////////////////////////////////////////////////// | ||||
| // Copyright 2017 eyck@minres.com | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); you may not | ||||
| // use this file except in compliance with the License.  You may obtain a copy | ||||
| // of the License at | ||||
| // | ||||
| //   http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
| // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the | ||||
| // License for the specific language governing permissions and limitations under | ||||
| // the License. | ||||
| //////////////////////////////////////////////////////////////////////////////// | ||||
| /* | ||||
|  * sc_main.cpp | ||||
|  * | ||||
|  *  Created on: 17.09.2017 | ||||
|  *      Author: eyck@minres.com | ||||
|  */ | ||||
|  | ||||
| #include <scc/report.h> | ||||
| #include <scc/tracer.h> | ||||
| #include <boost/program_options.hpp> | ||||
| #include <scc/ordered_semaphore.h> | ||||
| using namespace scc; | ||||
| namespace po = boost::program_options; | ||||
|  | ||||
| namespace { | ||||
| const size_t ERROR_IN_COMMAND_LINE = 1; | ||||
| const size_t SUCCESS = 0; | ||||
| const size_t ERROR_UNHANDLED_EXCEPTION = 2; | ||||
| } // namespace | ||||
|  | ||||
|  | ||||
| class top: public sc_core::sc_module { | ||||
| public: | ||||
|     top(sc_core::sc_module_name const&){ | ||||
|         SC_HAS_PROCESS(top); | ||||
|         SC_THREAD(run); | ||||
|     } | ||||
|     ~top() override= default;; | ||||
| private: | ||||
|     void run(){ | ||||
|         sem.wait(); | ||||
|         sem_t.wait(); | ||||
|         sem.set_capacity(4); | ||||
|         sem_t.set_capacity(4); | ||||
|         sem_t.post(); | ||||
|         sem.post(); | ||||
|         sc_core::sc_stop(); | ||||
|     } | ||||
|     scc::ordered_semaphore sem{"sem", 2}; | ||||
|     scc::ordered_semaphore_t<2> sem_t{"sem_t"}; | ||||
| }; | ||||
|  | ||||
|  | ||||
| int sc_main(int argc, char *argv[]) { | ||||
|     sc_core::sc_report_handler::set_actions( "/IEEE_Std_1666/deprecated", sc_core::SC_DO_NOTHING ); | ||||
|     sc_core::sc_report_handler::set_actions(sc_core::SC_ID_MORE_THAN_ONE_SIGNAL_DRIVER_, sc_core::SC_DO_NOTHING); | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     // CLI argument parsing | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     po::options_description desc("Options"); | ||||
|     // clang-format off | ||||
|     desc.add_options() | ||||
|     		("help,h",  "Print help message") | ||||
| 			("debug,d", "set debug level") | ||||
| 			("trace,t", "trace SystemC signals"); | ||||
|     // clang-format on | ||||
|     po::variables_map vm; | ||||
|     try { | ||||
|         po::store(po::parse_command_line(argc, argv, desc), vm); // can throw | ||||
|         // --help option | ||||
|         if (vm.count("help")) { | ||||
|             std::cout << "JIT-ISS simulator for AVR" << std::endl << desc << std::endl; | ||||
|             return SUCCESS; | ||||
|         } | ||||
|         po::notify(vm); // throws on error, so do after help in case | ||||
|         // there are any problems | ||||
|     } catch (po::error &e) { | ||||
|         std::cerr << "ERROR: " << e.what() << std::endl << std::endl; | ||||
|         std::cerr << desc << std::endl; | ||||
|         return ERROR_IN_COMMAND_LINE; | ||||
|     } | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     // configure logging | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     scc::init_logging(vm.count("debug")?scc::log::DEBUG:scc::log::INFO); | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     // instantiate top level | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     top tb("tb"); | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     // run simulation | ||||
|     /////////////////////////////////////////////////////////////////////////// | ||||
|     sc_start(sc_core::sc_time(1, sc_core::SC_MS)); | ||||
|     // todo: provide end-of-simulation macros | ||||
|  | ||||
|     if (!sc_core::sc_end_of_simulation_invoked()) { | ||||
|         SCCERR() << "simulation timed out"; | ||||
|         sc_core::sc_stop(); | ||||
|     } | ||||
|     auto errcnt = sc_core::sc_report_handler::get_count(sc_core::SC_ERROR); | ||||
|     auto warncnt = sc_core::sc_report_handler::get_count(sc_core::SC_WARNING); | ||||
|     SCCINFO() << "Finished, there were " << errcnt << " error" << (errcnt == 1 ? "" : "s") << " and " << warncnt << " warning" | ||||
|               << (warncnt == 1 ? "" : "s, 1 warning expected"); | ||||
|     return errcnt + (warncnt-1); | ||||
| } | ||||
							
								
								
									
										32
									
								
								tests/ordered_semaphore/test.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								tests/ordered_semaphore/test.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| #define SC_INCLUDE_DYNAMIC_PROCESSES | ||||
| #include <scc/ordered_semaphore.h> | ||||
| #include <scc/utilities.h> | ||||
| #include <factory.h> | ||||
| #include <catch2/catch_all.hpp> | ||||
| #include <systemc> | ||||
|  | ||||
| using namespace sc_core; | ||||
|  | ||||
| class top: public sc_core::sc_module { | ||||
| public: | ||||
|     scc::ordered_semaphore sem{"sem", 2}; | ||||
|     scc::ordered_semaphore_t<2> sem_t{"sem_t"}; | ||||
| }; | ||||
|  | ||||
| factory::add<top> tb; | ||||
|  | ||||
| TEST_CASE("simple ordered_semaphore test", "[SCC][ordered_semaphore]") { | ||||
|  | ||||
|     auto& dut = factory::get<top>(); | ||||
|     auto run1 = sc_spawn([&dut](){ | ||||
|         dut.sem.wait(); | ||||
|         dut.sem_t.wait(); | ||||
|         dut.sem.set_capacity(4); | ||||
|         dut.sem_t.set_capacity(4); | ||||
|         dut.sem_t.post(); | ||||
|         dut.sem.post(); | ||||
|     }); | ||||
|  | ||||
|     sc_start(1_ns); | ||||
|     REQUIRE(run1.terminated()); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user