2
0
mirror of https://github.com/boostorg/leaf.git synced 2026-01-24 18:02:22 +00:00
Files
leaf/test/error_capture_test.1.cpp
2019-01-01 23:01:26 -08:00

184 lines
3.1 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/error_capture.hpp>
#include <boost/leaf/expect.hpp>
#include "boost/core/lightweight_test.hpp"
namespace leaf = boost::leaf;
template <int> struct info { int value; };
leaf::error f()
{
return leaf::error(info<1>{1},info<3>{3});
}
leaf::error_capture make_capture()
{
leaf::expect<info<1>,info<2>,info<3>> exp;
return capture(exp,f());
}
int main()
{
leaf::error_capture ec = make_capture();
{
int c=0;
bool r = handle_error( ec,
[&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( ec,
[&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( ec,
[&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( ec,
[&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( ec,
[&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( ec,
[&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);
}
{
leaf::expect<info<1>,info<2>,info<3>> exp;
leaf::error e1( info<1>{-1}, info<2>{-2}, info<3>{-3} );
leaf::error e2 = ec.unload();
{
int c = 0;
bool r = handle_error( exp, e1,
[&c]( info<1>, info<2>, info<3> )
{
BOOST_TEST(c==0);
c = 1;
},
[&c]( info<1>, info<3> )
{
BOOST_TEST(c==0);
c = 2;
},
[&c]( info<2> const & y )
{
BOOST_TEST(c==0);
BOOST_TEST(y.value==-2);
c = 3;
} );
BOOST_TEST(r);
BOOST_TEST(c==3);
}
{
int c = 0;
bool r = handle_error( exp, e2,
[&c]( info<1>, info<2>, info<3> )
{
BOOST_TEST(c==0);
c = 1;
},
[&c]( info<2> const & y )
{
BOOST_TEST(c==0);
c = 2;
},
[&c]( info<1> const & x, info<3> const & z )
{
BOOST_TEST(c==0);
BOOST_TEST(x.value==1);
BOOST_TEST(z.value==3);
c = 3;
} );
BOOST_TEST(r);
BOOST_TEST(c==3);
}
}
return boost::report_errors();
}