safe_numerics/test/test_modulus.hpp
Robert Ramey 82bf4359c7 minor changes for warnings
simplify passing of constant strings.
2019-03-01 13:30:18 -08:00

154 lines
4.6 KiB
C++

#ifndef BOOST_TEST_MODULUS_HPP
#define BOOST_TEST_MODULUS_HPP
// Copyright (c) 2015 Robert Ramey
//
// 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 <iostream>
#include <boost/safe_numerics/safe_integer.hpp>
#include <boost/safe_numerics/range_value.hpp>
template<class T1, class T2>
bool test_modulus(
T1 v1,
T2 v2,
const char *av1,
const char *av2,
char expected_result
){
std::cout << "testing"<< std::endl;
{
safe_t<T1> t1 = v1;
using result_type = decltype(t1 % v2);
std::cout << "safe<" << av1 << "> % " << av2 << " -> ";
static_assert(
boost::safe_numerics::is_safe<safe_t<T1> >::value,
"safe_t not safe!"
);
static_assert(
boost::safe_numerics::is_safe<result_type>::value,
"Expression failed to return safe type"
);
try{
// use auto to avoid checking assignment.
auto result = t1 % v2;
std::cout << make_result_display(result);
if(expected_result == 'x'){
std::cout
<< " ! = "<< av1 << " % " << av2
<< " failed to detect error in modulus"
<< std::endl;
t1 % v2;
return false;
}
std::cout << std::endl;
}
catch(const std::exception &){
if(expected_result == '.'){
std::cout
<< " == "<< av1 << " % " << av2
<< " erroneously detected error in modulus"
<< std::endl;
try{
t1 % v2;
}
catch(const std::exception &){}
return false;
}
}
}
{
safe_t<T2> t2 = v2;
using result_type = decltype(v1 % t2);
std::cout << av1 << " % " << "safe<" << av2 << "> -> ";
static_assert(
boost::safe_numerics::is_safe<safe_t<T2> >::value,
"safe_t not safe!"
);
static_assert(
boost::safe_numerics::is_safe<result_type>::value,
"Expression failed to return safe type"
);
try{
// use auto to avoid checking assignment.
auto result = v1 % t2;
std::cout << make_result_display(result);
if(expected_result =='x'){
std::cout
<< " ! = "<< av1 << " % " << av2
<< " failed to detect error in modulus"
<< std::endl;
try{
v1 % t2;
}
catch(const std::exception &){}
return false;
}
std::cout << std::endl;
}
catch(const std::exception &){
if(expected_result != 'x'){
std::cout
<< " == "<< av1 << " % " << av2
<< " erroneously detected error in modulus"
<< std::endl;
try{
v1 % t2;
}
catch(const std::exception &){}
return false;
}
}
}
{
safe_t<T1> t1 = v1;
safe_t<T2> t2 = v2;
using result_type = decltype(t1 + t2);
std::cout << "safe<" << av1 << "> % " << "safe<" << av2 << "> -> ";
static_assert(
boost::safe_numerics::is_safe<result_type>::value,
"Expression failed to return safe type"
);
try{
// use auto to avoid checking assignment.
auto result = t1 % t2;
std::cout << make_result_display(result);
if(expected_result != '.'){
std::cout
<< " ! = "<< av1 << " % " << av2
<< " failed to detect error in modulus"
<< std::endl;
try{
t1 % t2;
}
catch(const std::exception &){}
return false;
}
std::cout << std::endl;
}
catch(const std::exception &){
if(expected_result != 'x'){
std::cout
<< " == "<< av1 << " % " << av2
<< " erroneously detected error in modulus"
<< std::endl;
try{
t1 % t2;
}
catch(const std::exception &){}
return false;
}
}
}
return true;
}
#endif // BOOST_TEST_MODULUS