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

Catch2 v3.4 as static lib; U22 in GHA #12257

Merged
merged 4 commits into from
Oct 5, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
14 changes: 4 additions & 10 deletions .github/workflows/buildsCI.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -249,8 +249,8 @@ jobs:


#--------------------------------------------------------------------------------
U20_ST_Py_EX_CfU_LiveTest: # Ubuntu 2020, Static, Python, Examples & Tools, Check for Updates, Legacy Live-Tests
runs-on: ubuntu-20.04
U22_ST_Py_EX_CfU_LiveTest: # Ubuntu 2022, Static, Python, Examples & Tools, Check for Updates, Legacy Live-Tests
runs-on: ubuntu-22.04
timeout-minutes: 60
steps:
- uses: actions/checkout@v3
Expand All @@ -267,9 +267,6 @@ jobs:
sudo apt-get install -qq libusb-1.0-0-dev;
sudo apt-get install -qq libgtk-3-dev;
sudo apt-get install libglfw3-dev libglfw3;
# We force compiling with GCC 7 because the default installed GCC 9 compiled with LTO and gives an internal compiler error
sudo apt-get install gcc-7 g++-7;
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-7 60 --slave /usr/bin/g++ g++ /usr/bin/g++-7;

- name: Build
shell: bash
Expand Down Expand Up @@ -399,8 +396,8 @@ jobs:


#--------------------------------------------------------------------------------
U20_SH_RSUSB_LiveTest: # Ubuntu 2020, Shared, Legacy live-tests
runs-on: ubuntu-20.04
U22_SH_RSUSB_LiveTest: # Ubuntu 2022, Shared, Legacy live-tests
runs-on: ubuntu-22.04
timeout-minutes: 60
env:
LRS_BUILD_NODEJS: true
Expand All @@ -426,9 +423,6 @@ jobs:
sudo apt-get install -qq libusb-1.0-0-dev;
sudo apt-get install -qq libgtk-3-dev;
sudo apt-get install libglfw3-dev libglfw3;
# We force compiling with GCC 7 because the default installed GCC 9 compiled with LTO and gives an internal compiler error
sudo apt-get install gcc-7 g++-7;
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-7 60 --slave /usr/bin/g++ g++ /usr/bin/g++-7;

- name: Build
shell: bash
Expand Down
19 changes: 19 additions & 0 deletions CMake/catch2-download.cmake.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
cmake_minimum_required(VERSION 3.6)
project(catch2-download NONE)

include(ExternalProject)
ExternalProject_Add(
catch2
PREFIX .
GIT_REPOSITORY https://github.com/catchorg/Catch2.git
GIT_TAG v3.4.0
GIT_CONFIG advice.detachedHead=false # otherwise we'll get "You are in 'detached HEAD' state..."
SOURCE_DIR "${CMAKE_BINARY_DIR}/third-party/catch2"
GIT_SHALLOW 1 # No history needed (requires cmake 3.6)
# Override default steps with no action, we just want the clone step.
CONFIGURE_COMMAND ""
BUILD_COMMAND ""
INSTALL_COMMAND ""
)


51 changes: 51 additions & 0 deletions CMake/external_catch2.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
cmake_minimum_required(VERSION 3.10)
include(ExternalProject)


# We use a function to enforce a scoped variables creation only for the build
# (i.e turn off BUILD_SHARED_LIBS which is used on LRS build as well)
function(get_catch2)

message( STATUS "Fetching Catch2..." )

# We want to clone the repo and build it here, during configuration, so we can use it.
# But ExternalProject_add is limited in that it only does its magic during build.
# This is possible in CMake 3.12+ with FetchContent and FetchContent_MakeAvailable in 3.14+ (meaning Ubuntu 20)
# but we need to adhere to CMake 3.10 (Ubuntu 18).
# So instead, we invoke a new CMake project just to download it:
configure_file( CMake/catch2-download.cmake.in
${CMAKE_BINARY_DIR}/external-projects/catch2-download/CMakeLists.txt )
execute_process( COMMAND "${CMAKE_COMMAND}" -G "${CMAKE_GENERATOR}" .
-DCMAKE_MAKE_PROGRAM=${CMAKE_MAKE_PROGRAM}
-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}
-DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/external-projects/catch2-download"
OUTPUT_QUIET
RESULT_VARIABLE configure_ret )
execute_process( COMMAND "${CMAKE_COMMAND}" --build .
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/external-projects/catch2-download"
OUTPUT_QUIET
RESULT_VARIABLE build_ret )

if( configure_ret OR build_ret )
message( FATAL_ERROR "Failed to download catchorg/catch2" )
endif()

# We use cached variables so the default parameter inside the sub directory will not override the required values
# We add "FORCE" so that is a previous cached value is set our assignment will override it.
set( CATCH_INSTALL_DOCS OFF CACHE INTERNAL "" FORCE )
set( CATCH_INSTALL_EXTRAS OFF CACHE INTERNAL "" FORCE )

add_subdirectory( "${CMAKE_BINARY_DIR}/third-party/catch2"
"${CMAKE_BINARY_DIR}/third-party/catch2/build" )

# place libraries with other 3rd-party projects
set_target_properties( Catch2 Catch2WithMain PROPERTIES
FOLDER "ExternalProjectTargets/catch2" )

message( STATUS "Fetching Catch2 - Done" )

endfunction()


get_catch2()
3 changes: 0 additions & 3 deletions CMake/external_json.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,8 @@ function(get_nlohmann_json)
${CMAKE_BINARY_DIR}/external-projects/json-download/CMakeLists.txt )
execute_process( COMMAND "${CMAKE_COMMAND}" -G "${CMAKE_GENERATOR}" .
-DCMAKE_MAKE_PROGRAM=${CMAKE_MAKE_PROGRAM}
-DCMAKE_CXX_STANDARD_LIBRARIES=${CMAKE_CXX_STANDARD_LIBRARIES}
-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}
-DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}
-DANDROID_ABI=${ANDROID_ABI}
-DANDROID_STL=${ANDROID_STL}
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/external-projects/json-download"
OUTPUT_QUIET
RESULT_VARIABLE configure_ret )
Expand Down
1 change: 1 addition & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@ elseif(BUILD_TOOLS)
endif()

if(BUILD_UNIT_TESTS OR BUILD_LEGACY_LIVE_TEST)
include( CMake/external_catch2.cmake )
add_subdirectory(unit-tests)
endif()

Expand Down
8 changes: 4 additions & 4 deletions unit-tests/approx.h
Original file line number Diff line number Diff line change
Expand Up @@ -103,9 +103,9 @@ We provide our own functions to do approximate comparison:
// Custom version of Approx, ==> better replaced by matchers <== for more control,
// but provides LRS defaults that should closely (but not exactly) match them
template< typename F >
inline Approx approx( F f )
inline Catch::Approx approx( F f )
{
return Approx( f )
return Catch::Approx( f )
.margin( __approx_margin< F >::value() )
.epsilon( __approx_epsilon< F >::value() );
}
Expand Down Expand Up @@ -138,9 +138,9 @@ Or, with the Catch matchers, even more:
These matchers are type-sensitive (float vs. double).
*/
#define approx_abs(D) \
Catch::WithinAbs( (D), approx_margin((D)) )
Catch::Matchers::WithinAbs( (D), approx_margin((D)) )
#define approx_rel(D) \
Catch::WithinRel( (D), approx_epsilon((D)) )
Catch::Matchers::WithinRel( (D), approx_epsilon((D)) )
#define approx_equals(D) \
( approx_abs(D) || approx_rel(D) )

Expand Down
64 changes: 1 addition & 63 deletions unit-tests/catch.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,66 +14,4 @@
#error CATCH_CONFIG_MAIN must not be defined: to run your own main(), use CATCH_CONFIG_RUNNER with #cmake:custom-main
#endif

#include "catch/catch.hpp"

#if defined(CATCH_CONFIG_RUNNER)

namespace Catch
{

// Allow custom test-cases on the fly
class CustomRunContext : public RunContext
{
public:
CustomRunContext( CustomRunContext const& ) = delete;
CustomRunContext & operator=( CustomRunContext const& ) = delete;

// RunContext ctor, but you need to give details...
explicit CustomRunContext( IStreamingReporterPtr&& reporter, IConfigPtr const& cfg )
: RunContext( cfg, std::move( reporter ))
{
}

// Easy way to instantiate, using the compact reporter by default
explicit CustomRunContext( std::string const & reporter_type = "compact", IConfigPtr const & cfg = IConfigPtr( new Config ) )
: CustomRunContext( getRegistryHub().getReporterRegistry().create( reporter_type, cfg ), cfg )
{
}

// Easy way to instantiate, using config data first
explicit CustomRunContext( Catch::ConfigData const & cfg, std::string const & reporter_type = "compact" )
: CustomRunContext( reporter_type, IConfigPtr( new Config( cfg ) ) )
{
}

// Allow changing the redirection for the reporter by force (the compact reporter does
// not allow changing via the Config's verbosity)
void set_redirection( bool on )
{
auto r = dynamic_cast<Catch::CompactReporter *>(&reporter());
if( r )
r->m_reporterPrefs.shouldRedirectStdOut = on;
}

template< class T >
Totals run_test( std::string const & name, T test )
{
struct invoker : ITestInvoker
{
T _test;
invoker( T t ) : _test( t ) {}
void invoke() const override
{
_test();
}
};
TestCase test_case( new invoker( test ),
TestCaseInfo( name, {}, {}, {}, {"",0} )
);
return runTest( test_case );
}
};

} // namespace Catch

#endif // CATCH_CONFIG_RUNNER
#include <catch2/catch_all.hpp>
Loading