mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-16 10:42:25 +01:00
Fix preprocessor check for enabling FP reproducibility tests
This solves warning about the `uniform_fp_test_params` helper being unused on M1 mac (or any other platform using GCC and not using SSE2). Closes #2845
This commit is contained in:
parent
355a6e273b
commit
0a6a2ce887
@ -495,6 +495,22 @@ TEMPLATE_TEST_CASE( "uniform_integer_distribution is reproducible",
|
|||||||
REQUIRE_THAT(generated, Catch::Matchers::RangeEquals(uniform_integer_test_params<TestType>::expected));
|
REQUIRE_THAT(generated, Catch::Matchers::RangeEquals(uniform_integer_test_params<TestType>::expected));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The reproducibility tests assume that operations on `float`/`double`
|
||||||
|
// happen in the same precision as the operated-upon type. This is
|
||||||
|
// generally true, unless the code is compiled for 32 bit targets without
|
||||||
|
// SSE2 enabled, in which case the operations are done in the x87 FPU,
|
||||||
|
// which usually implies doing math in 80 bit floats, and then rounding
|
||||||
|
// into smaller type when the type is saved into memory. This obviously
|
||||||
|
// leads to a different answer, than doing the math in the correct precision.
|
||||||
|
#if ( defined( _MSC_VER ) && _M_IX86_FP < 2 ) || \
|
||||||
|
( defined( __GNUC__ ) && \
|
||||||
|
( ( defined( __i386__ ) || defined( __x86_64__ ) ) ) && \
|
||||||
|
!defined( __SSE2_MATH__ ) )
|
||||||
|
# define CATCH_TEST_CONFIG_DISABLE_FLOAT_REPRODUCIBILITY_TESTS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined( CATCH_TEST_CONFIG_DISABLE_FLOAT_REPRODUCIBILITY_TESTS )
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct uniform_fp_test_params;
|
struct uniform_fp_test_params;
|
||||||
@ -552,20 +568,6 @@ namespace {
|
|||||||
#endif
|
#endif
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
// The reproducibility tests assume that operations on `float`/`double`
|
|
||||||
// happen in the same precision as the operated-upon type. This is
|
|
||||||
// generally true, unless the code is compiled for 32 bit targets without
|
|
||||||
// SSE2 enabled, in which case the operations are done in the x87 FPU,
|
|
||||||
// which usually implies doing math in 80 bit floats, and then rounding
|
|
||||||
// into smaller type when the type is saved into memory. This obviously
|
|
||||||
// leads to a different answer, than doing the math in the correct precision.
|
|
||||||
#if ( defined( _MSC_VER ) && _M_IX86_FP < 2 ) || \
|
|
||||||
( defined( __GNUC__ ) && !defined( __SSE2_MATH__ ) )
|
|
||||||
# define CATCH_TEST_CONFIG_DISABLE_FLOAT_REPRODUCIBILITY_TESTS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined( CATCH_TEST_CONFIG_DISABLE_FLOAT_REPRODUCIBILITY_TESTS )
|
|
||||||
|
|
||||||
TEMPLATE_TEST_CASE( "uniform_floating_point_distribution is reproducible",
|
TEMPLATE_TEST_CASE( "uniform_floating_point_distribution is reproducible",
|
||||||
"[rng][distribution][floating-point][approvals]",
|
"[rng][distribution][floating-point][approvals]",
|
||||||
float,
|
float,
|
||||||
@ -596,7 +598,7 @@ TEMPLATE_TEST_CASE( "uniform_floating_point_distribution can handle unitary rang
|
|||||||
CAPTURE( seed );
|
CAPTURE( seed );
|
||||||
Catch::SimplePcg32 pcg( seed );
|
Catch::SimplePcg32 pcg( seed );
|
||||||
|
|
||||||
const auto highest = uniform_fp_test_params<TestType>::highest;
|
const auto highest = TestType(385.125);
|
||||||
Catch::uniform_floating_point_distribution<TestType> dist( highest,
|
Catch::uniform_floating_point_distribution<TestType> dist( highest,
|
||||||
highest );
|
highest );
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user