mirror of
https://github.com/boostorg/core.git
synced 2025-07-30 04:47:24 +02:00
Merge branch 'breese-feature/test-all-with' into develop
This commit is contained in:
@ -39,6 +39,7 @@ When using `lightweight_test.hpp`, *do not forget* to
|
|||||||
#define BOOST_TEST_CSTR_EQ(expr1, expr2) /*unspecified*/
|
#define BOOST_TEST_CSTR_EQ(expr1, expr2) /*unspecified*/
|
||||||
#define BOOST_TEST_CSTR_NE(expr1, expr2) /*unspecified*/
|
#define BOOST_TEST_CSTR_NE(expr1, expr2) /*unspecified*/
|
||||||
#define BOOST_TEST_ALL_EQ(begin1, end1, begin2, end2) /* unspecified */
|
#define BOOST_TEST_ALL_EQ(begin1, end1, begin2, end2) /* unspecified */
|
||||||
|
#define BOOST_TEST_ALL_WITH(begin1, end1, begin2, end2, predicate) /* unspecified */
|
||||||
#define BOOST_TEST_THROWS(expr, excep) /*unspecified*/
|
#define BOOST_TEST_THROWS(expr, excep) /*unspecified*/
|
||||||
|
|
||||||
namespace boost
|
namespace boost
|
||||||
@ -132,6 +133,16 @@ Compares the content of two sequences. If they have different sizes, or if any p
|
|||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
|
[section BOOST_TEST_ALL_WITH]
|
||||||
|
|
||||||
|
``
|
||||||
|
BOOST_TEST_ALL_WITH(begin1, end1, begin2, end2, predicate)
|
||||||
|
``
|
||||||
|
|
||||||
|
Compares the content of two sequences. If they have different sizes, or if any pairwise element do not fulfill the binary predicate, increases the error count and outputs a message containing at most 8 differing elements.
|
||||||
|
|
||||||
|
[endsect]
|
||||||
|
|
||||||
[section BOOST_TEST_THROWS]
|
[section BOOST_TEST_THROWS]
|
||||||
|
|
||||||
``
|
``
|
||||||
|
@ -249,6 +249,75 @@ void test_all_eq_impl(FormattedOutputFunction& output,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<class FormattedOutputFunction, class InputIterator1, class InputIterator2, typename BinaryPredicate>
|
||||||
|
void test_all_with_impl(FormattedOutputFunction& output,
|
||||||
|
char const * file, int line, char const * function,
|
||||||
|
InputIterator1 first_begin, InputIterator1 first_end,
|
||||||
|
InputIterator2 second_begin, InputIterator2 second_end,
|
||||||
|
BinaryPredicate predicate)
|
||||||
|
{
|
||||||
|
InputIterator1 first_it = first_begin;
|
||||||
|
InputIterator2 second_it = second_begin;
|
||||||
|
typename std::iterator_traits<InputIterator1>::difference_type first_index = 0;
|
||||||
|
typename std::iterator_traits<InputIterator2>::difference_type second_index = 0;
|
||||||
|
std::size_t error_count = 0;
|
||||||
|
const std::size_t max_count = 8;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
while ((first_it != first_end) && (second_it != second_end) && predicate(*first_it, *second_it))
|
||||||
|
{
|
||||||
|
++first_it;
|
||||||
|
++second_it;
|
||||||
|
++first_index;
|
||||||
|
++second_index;
|
||||||
|
}
|
||||||
|
if ((first_it == first_end) || (second_it == second_end))
|
||||||
|
{
|
||||||
|
break; // do-while
|
||||||
|
}
|
||||||
|
if (error_count == 0)
|
||||||
|
{
|
||||||
|
output << file << "(" << line << "): Container contents differ in function '" << function << "':";
|
||||||
|
}
|
||||||
|
else if (error_count >= max_count)
|
||||||
|
{
|
||||||
|
output << " ...";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
output << " [" << first_index << "]";
|
||||||
|
++first_it;
|
||||||
|
++second_it;
|
||||||
|
++first_index;
|
||||||
|
++second_index;
|
||||||
|
++error_count;
|
||||||
|
} while (first_it != first_end);
|
||||||
|
|
||||||
|
first_index += std::distance(first_it, first_end);
|
||||||
|
second_index += std::distance(second_it, second_end);
|
||||||
|
if (first_index != second_index)
|
||||||
|
{
|
||||||
|
if (error_count == 0)
|
||||||
|
{
|
||||||
|
output << file << "(" << line << "): Container sizes differ in function '" << function << "': size(" << first_index << ") != size(" << second_index << ")";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
output << " [*] size(" << first_index << ") != size(" << second_index << ")";
|
||||||
|
}
|
||||||
|
++error_count;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (error_count == 0)
|
||||||
|
{
|
||||||
|
report_errors_remind();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
output << std::endl;
|
||||||
|
++test_errors();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(_MSC_VER)
|
#if defined(_MSC_VER)
|
||||||
# pragma warning(pop)
|
# pragma warning(pop)
|
||||||
#elif defined(__clang__) && defined(__has_warning)
|
#elif defined(__clang__) && defined(__has_warning)
|
||||||
@ -295,6 +364,7 @@ inline int report_errors()
|
|||||||
#define BOOST_TEST_CSTR_NE(expr1,expr2) ( ::boost::detail::test_cstr_ne_impl(#expr1, #expr2, __FILE__, __LINE__, BOOST_CURRENT_FUNCTION, expr1, expr2) )
|
#define BOOST_TEST_CSTR_NE(expr1,expr2) ( ::boost::detail::test_cstr_ne_impl(#expr1, #expr2, __FILE__, __LINE__, BOOST_CURRENT_FUNCTION, expr1, expr2) )
|
||||||
|
|
||||||
#define BOOST_TEST_ALL_EQ(begin1, end1, begin2, end2) ( ::boost::detail::test_all_eq_impl(BOOST_LIGHTWEIGHT_TEST_OSTREAM, __FILE__, __LINE__, BOOST_CURRENT_FUNCTION, begin1, end1, begin2, end2) )
|
#define BOOST_TEST_ALL_EQ(begin1, end1, begin2, end2) ( ::boost::detail::test_all_eq_impl(BOOST_LIGHTWEIGHT_TEST_OSTREAM, __FILE__, __LINE__, BOOST_CURRENT_FUNCTION, begin1, end1, begin2, end2) )
|
||||||
|
#define BOOST_TEST_ALL_WITH(begin1, end1, begin2, end2, predicate) ( ::boost::detail::test_all_with_impl(BOOST_LIGHTWEIGHT_TEST_OSTREAM, __FILE__, __LINE__, BOOST_CURRENT_FUNCTION, begin1, end1, begin2, end2, predicate) )
|
||||||
|
|
||||||
#ifndef BOOST_NO_EXCEPTIONS
|
#ifndef BOOST_NO_EXCEPTIONS
|
||||||
#define BOOST_TEST_THROWS( EXPR, EXCEP ) \
|
#define BOOST_TEST_THROWS( EXPR, EXCEP ) \
|
||||||
|
@ -66,6 +66,8 @@ run lightweight_test_test.cpp : : : <exception-handling>off : lightweight_test_t
|
|||||||
|
|
||||||
run lightweight_test_test2.cpp ;
|
run lightweight_test_test2.cpp ;
|
||||||
run lightweight_test_all_eq_test.cpp ;
|
run lightweight_test_all_eq_test.cpp ;
|
||||||
|
run lightweight_test_all_with_test.cpp ;
|
||||||
|
run lightweight_test_all_with_fail.cpp ;
|
||||||
|
|
||||||
run-fail lightweight_test_fail.cpp ;
|
run-fail lightweight_test_fail.cpp ;
|
||||||
run-fail lightweight_test_fail2.cpp ;
|
run-fail lightweight_test_fail2.cpp ;
|
||||||
|
107
test/lightweight_test_all_with_fail.cpp
Normal file
107
test/lightweight_test_all_with_fail.cpp
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
//
|
||||||
|
// Negative est for BOOST_TEST_ALL_WITH
|
||||||
|
//
|
||||||
|
// Copyright (c) 2017 Bjorn Reese
|
||||||
|
//
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// See accompanying file LICENSE_1_0.txt or copy at
|
||||||
|
// http://www.boost.org/LICENSE_1_0.txt
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
|
#include <functional>
|
||||||
|
#include <vector>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
int fail_vector()
|
||||||
|
{
|
||||||
|
int test_cases = 0;
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::equal_to<int>() );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
y.push_back( 1 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::equal_to<int>() );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 ); x.push_back( 4 );
|
||||||
|
y.push_back( 1 ); y.push_back( 2 ); y.push_back( 3 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::equal_to<int>() );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 );
|
||||||
|
y.push_back( 1 ); y.push_back( 2 ); y.push_back( 3 ); y.push_back( 4 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::equal_to<int>() );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 ); x.push_back( 4 );
|
||||||
|
y.push_back( 1 ); y.push_back( 3 ); y.push_back( 2 ); y.push_back( 4 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::equal_to<int>() );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 ); x.push_back( 4 );
|
||||||
|
y.push_back( 1 ); y.push_back( 3 ); y.push_back( 2 ); y.push_back( 4 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::less<int>() );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
return test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct with_tolerance
|
||||||
|
{
|
||||||
|
with_tolerance(T tolerance) : tolerance(tolerance) {}
|
||||||
|
bool operator()(T lhs, T rhs)
|
||||||
|
{
|
||||||
|
return (std::abs(lhs - rhs) <= tolerance);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
T tolerance;
|
||||||
|
};
|
||||||
|
|
||||||
|
int fail_tolerance_predicate()
|
||||||
|
{
|
||||||
|
int test_cases = 0;
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<double> x, y;
|
||||||
|
x.push_back( 1.0 ); x.push_back( 1.0 );
|
||||||
|
y.push_back( 1.0 - 1e-4 ); y.push_back( 1.0 + 1e-4 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), with_tolerance<double>(1e-5) );
|
||||||
|
++test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
return test_cases;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int test_cases = 0;
|
||||||
|
|
||||||
|
test_cases += fail_vector();
|
||||||
|
test_cases += fail_tolerance_predicate();
|
||||||
|
|
||||||
|
boost::report_errors();
|
||||||
|
|
||||||
|
return boost::detail::test_errors() != test_cases;
|
||||||
|
}
|
76
test/lightweight_test_all_with_test.cpp
Normal file
76
test/lightweight_test_all_with_test.cpp
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
//
|
||||||
|
// Test for BOOST_TEST_ALL_WITH
|
||||||
|
//
|
||||||
|
// Copyright (c) 2017 Bjorn Reese
|
||||||
|
//
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// See accompanying file LICENSE_1_0.txt or copy at
|
||||||
|
// http://www.boost.org/LICENSE_1_0.txt
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
|
#include <functional>
|
||||||
|
#include <vector>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
void test_vector()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 ); x.push_back( 4 );
|
||||||
|
y.push_back( 1 ); y.push_back( 2 ); y.push_back( 3 ); y.push_back( 4 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::equal_to<int>() );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 ); x.push_back( 4 );
|
||||||
|
y.push_back( 2 ); y.push_back( 3 ); y.push_back( 4 ); y.push_back( 5 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::not_equal_to<int>() );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<int> x, y;
|
||||||
|
x.push_back( 1 ); x.push_back( 2 ); x.push_back( 3 ); x.push_back( 4 );
|
||||||
|
y.push_back( 2 ); y.push_back( 3 ); y.push_back( 4 ); y.push_back( 5 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), std::less<int>() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct with_tolerance
|
||||||
|
{
|
||||||
|
with_tolerance(T tolerance) : tolerance(tolerance) {}
|
||||||
|
bool operator()(T lhs, T rhs)
|
||||||
|
{
|
||||||
|
return (std::abs(lhs - rhs) <= tolerance);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
T tolerance;
|
||||||
|
};
|
||||||
|
|
||||||
|
void test_tolerance_predicate()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
std::vector<double> x, y;
|
||||||
|
x.push_back( 1.0 ); x.push_back( 2.0 ); x.push_back( 3.0 ); x.push_back( 4.0 );
|
||||||
|
y.push_back( 1.0 ); y.push_back( 2.0 ); y.push_back( 3.0 ); y.push_back( 4.0 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), with_tolerance<double>(1e-5) );
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::vector<double> x, y;
|
||||||
|
x.push_back( 1.0 ); x.push_back( 1.0 );
|
||||||
|
y.push_back( 1.0 - 1e-6 ); y.push_back( 1.0 + 1e-6 );
|
||||||
|
BOOST_TEST_ALL_WITH( x.begin(), x.end(), y.begin(), y.end(), with_tolerance<double>(1e-5) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
test_vector();
|
||||||
|
test_tolerance_predicate();
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
Reference in New Issue
Block a user