tuple: split tests into separate units
This commit is contained in:
parent
8f2f623520
commit
5f2b1a5c36
@ -537,7 +537,8 @@ if (TESTS)
|
|||||||
thread/ticketlock
|
thread/ticketlock
|
||||||
time/8601
|
time/8601
|
||||||
traits
|
traits
|
||||||
tuple
|
tuple/value
|
||||||
|
tuple/type
|
||||||
typeidx
|
typeidx
|
||||||
uri
|
uri
|
||||||
utf8
|
utf8
|
||||||
|
@ -1,12 +1,8 @@
|
|||||||
#include "tuple/type.hpp"
|
|
||||||
#include "tuple/value.hpp"
|
|
||||||
|
|
||||||
#include "tap.hpp"
|
#include "tap.hpp"
|
||||||
|
|
||||||
#include <array>
|
#include "tuple/type.hpp"
|
||||||
#include <typeindex>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
|
#include <typeindex>
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct int_mapper
|
struct int_mapper
|
||||||
@ -14,30 +10,19 @@ struct int_mapper
|
|||||||
typedef int type;
|
typedef int type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
main ()
|
main (void)
|
||||||
{
|
{
|
||||||
util::TAP::logger tap;
|
util::TAP::logger tap;
|
||||||
|
|
||||||
static_assert (
|
|
||||||
util::tuple::type::index<
|
|
||||||
std::tuple<float,int,void>,
|
|
||||||
int
|
|
||||||
>::value == 1
|
|
||||||
);
|
|
||||||
|
|
||||||
{
|
{
|
||||||
auto tuple = std::make_tuple (1,2,3,4);
|
using tuple_t = std::tuple<float,int,void>;
|
||||||
std::vector<int> expected {{ 1, 2, 3, 4 }};
|
tap.expect_eq (util::tuple::type::index<tuple_t,int>::value, 1u, "tuple index extraction");
|
||||||
|
|
||||||
std::vector<int> actual;
|
|
||||||
util::tuple::value::each ([&actual] (auto i) { actual.push_back (i); }, tuple);
|
|
||||||
|
|
||||||
tap.expect_eq (actual, expected, "value iteration");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
#if !defined(NO_RTTI)
|
#if !defined(NO_RTTI)
|
||||||
auto tuple = std::make_tuple (1u, 1, 1.f, 1.);
|
auto tuple = std::make_tuple (1u, 1, 1.f, 1.);
|
||||||
std::vector<std::type_index> expected {
|
std::vector<std::type_index> expected {
|
||||||
std::type_index (typeid (1u)),
|
std::type_index (typeid (1u)),
|
||||||
@ -52,30 +37,18 @@ main ()
|
|||||||
});
|
});
|
||||||
|
|
||||||
tap.expect_eq (actual, expected, "type iteration");
|
tap.expect_eq (actual, expected, "type iteration");
|
||||||
#else
|
#else
|
||||||
tap.skip ("type iteration because no-rtti");
|
tap.skip ("type iteration because no-rtti");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
||||||
using src_t = std::tuple<std::string>;
|
using src_t = std::tuple<std::string>;
|
||||||
using dst_t = typename util::tuple::type::map<src_t, int_mapper>::type;
|
using dst_t = typename util::tuple::type::map<src_t, int_mapper>::type;
|
||||||
|
|
||||||
tap.expect (std::is_same<dst_t, std::tuple<int>>::value, "tuple type mapping");
|
tap.expect (std::is_same<dst_t, std::tuple<int>>::value, "tuple type mapping");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
{
|
|
||||||
std::tuple a (1, 2);
|
|
||||||
std::array<char,2> b { 'a', 'b' };
|
|
||||||
std::tuple c (
|
|
||||||
std::tuple(1, 'a'),
|
|
||||||
std::tuple(2, 'b')
|
|
||||||
);
|
|
||||||
|
|
||||||
tap.expect_eq (c, util::tuple::value::zip (a, b), "tuple zipping");
|
|
||||||
}
|
|
||||||
|
|
||||||
return tap.status ();
|
return tap.status ();
|
||||||
}
|
}
|
33
test/tuple/value.cpp
Normal file
33
test/tuple/value.cpp
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
#include "tap.hpp"
|
||||||
|
|
||||||
|
#include "tuple/value.hpp"
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
main (void)
|
||||||
|
{
|
||||||
|
util::TAP::logger tap;
|
||||||
|
|
||||||
|
{
|
||||||
|
auto tuple = std::make_tuple (1,2,3,4);
|
||||||
|
std::vector<int> expected {{ 1, 2, 3, 4 }};
|
||||||
|
|
||||||
|
std::vector<int> actual;
|
||||||
|
util::tuple::value::each ([&actual] (auto i) { actual.push_back (i); }, tuple);
|
||||||
|
|
||||||
|
tap.expect_eq (actual, expected, "value iteration");
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
std::tuple a (1, 2);
|
||||||
|
std::array<char,2> b { 'a', 'b' };
|
||||||
|
std::tuple c (
|
||||||
|
std::tuple(1, 'a'),
|
||||||
|
std::tuple(2, 'b')
|
||||||
|
);
|
||||||
|
|
||||||
|
tap.expect_eq (c, util::tuple::value::zip (a, b), "tuple zipping");
|
||||||
|
}
|
||||||
|
|
||||||
|
return tap.status ();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user