2
0
mirror of https://github.com/boostorg/leaf.git synced 2026-01-25 06:12:27 +00:00
Files
leaf/test/result_test.5.cpp
2019-01-01 23:01:26 -08:00

187 lines
3.3 KiB
C++

//Copyright (c) 2018 Emil Dotchevski
//Copyright (c) 2018 Second Spectrum, Inc.
//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 <boost/leaf/result.hpp>
#include <boost/leaf/expect.hpp>
#include "boost/core/lightweight_test.hpp"
namespace leaf = boost::leaf;
template <int> struct info { int value; };
leaf::result<void> f()
{
return leaf::error(info<1>{1},info<3>{3});
}
int main()
{
leaf::expect<info<1>,info<2>,info<3>> exp;
{
int c=0;
bool r = handle_error( exp, f(),
[&c]( info<1> const & x )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==1);
c = 1;
} );
BOOST_TEST(r);
BOOST_TEST(c==1);
}
{
int c=0;
bool r = handle_error( exp, f(),
[&c]( info<2> const & x )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==2);
c = 1;
} );
BOOST_TEST(!r);
BOOST_TEST(c==0);
}
{
int c=0;
int r = handle_error( exp, f(),
[&c]( info<1> const & x )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==1);
return c = 1;
} );
BOOST_TEST(r==1);
}
{
int c=0;
int r = handle_error( exp, f(),
[&c]( info<2> const & x )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==2);
return c = 1;
} );
BOOST_TEST(r==-1);
}
{
int c=0;
bool r = handle_error( exp, f(),
[&c]( info<1> const & x, info<2> const & )
{
BOOST_TEST(c==0);
c = 1;
},
[&c]( info<1> const & x, info<3> const & y )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==1);
BOOST_TEST(y.value==3);
c = 2;
return false;
},
[&c]( info<1> const & x )
{
BOOST_TEST(c==0);
c = 3;
} );
BOOST_TEST(!r);
BOOST_TEST(c==2);
}
{
int c=0;
bool r = handle_error( exp, f(),
[&c]( info<1> const & x, info<2> const & )
{
BOOST_TEST(c==0);
c = 1;
return false;
},
[&c]( info<1> const & x, info<3> const & y )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==1);
BOOST_TEST(y.value==3);
c = 2;
},
[&c]( info<1> const & x )
{
BOOST_TEST(c==0);
c = 3;
return false;
} );
BOOST_TEST(r);
BOOST_TEST(c==2);
}
{
int c=0;
leaf::result<int> r = handle_error( exp, f(),
[&c]( info<1> const & x, info<3> const & ) -> leaf::result<int>
{
BOOST_TEST(c==0);
c = 1;
return 42;
} );
BOOST_TEST(*r==42);
BOOST_TEST(c==1);
}
{
int c=0;
leaf::result<void> r1 = f();
leaf::expect<info<42>> exp1;
leaf::result<int> r2 = handle_error( exp, r1,
[&c]( info<1> const & x, info<3> const & ) -> leaf::result<int>
{
BOOST_TEST(c==0);
c = 1;
return leaf::error(info<42>{42});
} );
BOOST_TEST(c==1);
c = 0;
bool b = handle_error( exp1, r2,
[&c]( info<42> const & x )
{
BOOST_TEST(c==0);
c = 1;
BOOST_TEST(x.value==42);
} );
BOOST_TEST(b);
BOOST_TEST(c==1);
}
{
int c=0;
leaf::result<void> r1 = f();
leaf::result<int> r2 = handle_error( exp, r1,
[&c]( info<2> const & ) -> leaf::result<int>
{
BOOST_TEST(c==0);
c = 1;
return 42;
} );
BOOST_TEST(c==0);
bool b = handle_error( exp, r2,
[&c]( info<1> const & x, info<3> const & y )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==1);
BOOST_TEST(y.value==3);
c = 1;
} );
BOOST_TEST(b);
BOOST_TEST(c==1);
}
return boost::report_errors();
}