From 026baa925a5a23a9f7d2ce4b7c73db434995dbd2 Mon Sep 17 00:00:00 2001 From: jspam Date: Fri, 8 Jul 2022 12:42:57 +0200 Subject: [PATCH 1/2] Remove ::boost::test_tools::tt_detail::dummy_cond Replace loops using it by simple do { ... } while (0) loops. This allows static analysis tools like clang-tidy to better understand the code and avoid false positives. Fixes #343. --- include/boost/test/tools/detail/fwd.hpp | 2 -- include/boost/test/tools/interface.hpp | 14 +++++++------- include/boost/test/tools/old/interface.hpp | 6 +++--- 3 files changed, 10 insertions(+), 12 deletions(-) diff --git a/include/boost/test/tools/detail/fwd.hpp b/include/boost/test/tools/detail/fwd.hpp index 339ab39eda..cdec419580 100644 --- a/include/boost/test/tools/detail/fwd.hpp +++ b/include/boost/test/tools/detail/fwd.hpp @@ -42,8 +42,6 @@ class assertion_result; namespace tt_detail { -inline bool dummy_cond() { return false; } - // ************************************************************************** // // ************** types of supported assertions ************** // // ************************************************************************** // diff --git a/include/boost/test/tools/interface.hpp b/include/boost/test/tools/interface.hpp index e62ae946c0..24c408a2ef 100644 --- a/include/boost/test/tools/interface.hpp +++ b/include/boost/test/tools/interface.hpp @@ -55,7 +55,7 @@ do { \ ::boost::test_tools::tt_detail::level, \ ::boost::test_tools::tt_detail::CHECK_MSG, \ 0 ); \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ //____________________________________________________________________________// @@ -74,7 +74,7 @@ do { \ ::boost::test_tools::tt_detail::level, \ ::boost::test_tools::tt_detail::CHECK_BUILT_ASSERTION, \ 0 ); \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ //____________________________________________________________________________// @@ -98,7 +98,7 @@ do { \ ::boost::test_tools::tt_detail::assertion_type() \ << arg, \ 0 ); \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ //____________________________________________________________________________// @@ -121,7 +121,7 @@ do { \ BOOST_TEST_TOOL_DIRECT_IMPL( P, level, BOOST_TEST_STRINGIZE( P ) ); \ else \ BOOST_TEST_TOOL_ET_IMPL( P, level ); \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ #define BOOST_TEST_TOOL_UNIV_EX( level, P, ... ) \ @@ -177,7 +177,7 @@ do { try { \ BOOST_TEST_TOOL_DIRECT_IMPL( Ppassed, TL, Mpassed ); \ } catch( E ) { \ BOOST_TEST_TOOL_DIRECT_IMPL( Pcaught, TL, Mcaught ); \ -}} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +}} while( 0 ) \ /**/ #elif defined(BOOST_TEST_TOOLS_DEBUGGABLE) @@ -190,7 +190,7 @@ do { try { \ BOOST_TEST_TOOL_DIRECT_IMPL( Ppassed, TL, Mpassed ); \ } catch( E ) { \ BOOST_TEST_TOOL_DIRECT_IMPL( Pcaught, TL, Mcaught ); \ -}} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +}} while( 0 ) \ /**/ #else @@ -202,7 +202,7 @@ do { try { \ BOOST_TEST_TOOL_DIRECT_IMPL( Ppassed, TL, Mpassed ); \ } catch( E ) { \ BOOST_TEST_TOOL_DIRECT_IMPL( Pcaught, TL, Mcaught ); \ -}} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +}} while( 0 ) \ /**/ #endif diff --git a/include/boost/test/tools/old/interface.hpp b/include/boost/test/tools/old/interface.hpp index 1b23c291a3..b09b0cf3c6 100644 --- a/include/boost/test/tools/old/interface.hpp +++ b/include/boost/test/tools/old/interface.hpp @@ -72,7 +72,7 @@ do { ::boost::test_tools::tt_detail::TL, \ ::boost::test_tools::tt_detail::CT \ BOOST_JOIN( BOOST_TEST_TOOL_PASS_ARGS, frwd_type )( ARGS ) ); \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ //____________________________________________________________________________// @@ -110,7 +110,7 @@ do { "exception \"" BOOST_STRINGIZE( E )"\" raised as expected" postfix, \ TL, CHECK_MSG, _ ); \ } \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ //____________________________________________________________________________// @@ -140,7 +140,7 @@ do { BOOST_TEST_TOOL_IMPL( 2, false, "unexpected exception thrown by " BOOST_STRINGIZE( S ), \ TL, CHECK_MSG, _ ); \ } \ -} while( ::boost::test_tools::tt_detail::dummy_cond() ) \ +} while( 0 ) \ /**/ #define BOOST_WARN_NO_THROW( S ) BOOST_CHECK_NO_THROW_IMPL( S, WARN ) From acbccbecd276369976f53f72fb433f6af600d11a Mon Sep 17 00:00:00 2001 From: Wataru Matsumoto Date: Wed, 25 Sep 2024 07:11:23 +0800 Subject: [PATCH 2/2] Add BOOST_SYMBOL_VISIBLE to enum --- example/unit_test_example_16.cpp | 4 ++++ include/boost/test/detail/global_typedef.hpp | 18 +++++++++++------- 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/example/unit_test_example_16.cpp b/example/unit_test_example_16.cpp index fe239a9006..57e37b7f5d 100644 --- a/example/unit_test_example_16.cpp +++ b/example/unit_test_example_16.cpp @@ -20,6 +20,10 @@ bool init_unit_test() #if (!defined(BOOST_TEST_DYN_LINK) || (!defined(BOOST_CLANG) || (BOOST_CLANG != 1) || (__clang_major__ >= 8))) && !defined(__APPLE__) log_level logLevel = runtime_config::get(runtime_config::btrt_log_level); std::cout << "Current log level: " << static_cast(logLevel) << std::endl; + output_format logFormat = runtime_config::get(runtime_config::btrt_log_format); + std::cout << "Current log format: " << static_cast(logFormat) << std::endl; + report_level reportLevel = runtime_config::get(runtime_config::btrt_report_level); + std::cout << "Current report level: " << static_cast(reportLevel) << std::endl; #endif return true; } diff --git a/include/boost/test/detail/global_typedef.hpp b/include/boost/test/detail/global_typedef.hpp index 5e6f960737..19621ad679 100644 --- a/include/boost/test/detail/global_typedef.hpp +++ b/include/boost/test/detail/global_typedef.hpp @@ -29,17 +29,21 @@ typedef unsigned long counter_t; //____________________________________________________________________________// -enum report_level { INV_REPORT_LEVEL, CONFIRMATION_REPORT, SHORT_REPORT, DETAILED_REPORT, NO_REPORT }; +enum BOOST_SYMBOL_VISIBLE report_level { INV_REPORT_LEVEL, + CONFIRMATION_REPORT, + SHORT_REPORT, + DETAILED_REPORT, + NO_REPORT }; //____________________________________________________________________________// //! Indicates the output format for the loggers or the test tree printing -enum output_format { OF_INVALID, - OF_CLF, ///< compiler log format - OF_XML, ///< XML format for report and log, - OF_JUNIT, ///< JUNIT format for report and log, - OF_CUSTOM_LOGGER, ///< User specified logger. - OF_DOT ///< dot format for output content +enum BOOST_SYMBOL_VISIBLE output_format { OF_INVALID, + OF_CLF, ///< compiler log format + OF_XML, ///< XML format for report and log, + OF_JUNIT, ///< JUNIT format for report and log, + OF_CUSTOM_LOGGER, ///< User specified logger. + OF_DOT ///< dot format for output content }; //____________________________________________________________________________//