LUMIERA.clone/tests/library/meta/generator-combinations-test.cpp
Ichthyostega 412abbace2 clean-up: validate use of variadic seq with tuples and generators
Most of the type-list and type-sequence related eccosystem can be
just switched over, after having added the conversion variants for
the new-style variadic type sequences

Again this was used as opportunity to improve readability of related tests
2025-06-03 16:14:13 +02:00

131 lines
3.2 KiB
C++
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
GeneratorCombinations(Test) - verify generating case combinations
Copyright (C)
2011, Hermann Vosseler <Ichthyostega@web.de>
  **Lumiera** is free software; you can redistribute it and/or modify it
  under the terms of the GNU General Public License as published by the
  Free Software Foundation; either version 2 of the License, or (at your
  option) any later version. See the file COPYING for further details.
* *****************************************************************/
/** @file generator-combinations-test.cpp
** unit test \ref GeneratorCombinations_test
*/
#include "lib/test/run.hpp"
#include "lib/meta/generator.hpp"
#include "lib/meta/generator-combinations.hpp"
#include "meta/typelist-diagnostics.hpp"
#include "lib/format-string.hpp"
#include "lib/format-cout.hpp"
using ::test::Test;
using std::string;
namespace lib {
namespace meta {
namespace test {
namespace { // test cases and data....
typedef TySeq< Num<1>
, Num<3>
, Num<5>
> Types1;
typedef TySeq< Num<2>
, Num<4>
, Num<6>
> Types2;
using util::_Fmt;
/**
* A Test-Template to be instantiated
* for all possible combinations
* of the {Types1} x {Types2}
*/
template<class T1, class T2, class BASE>
struct TestCase
: BASE
{
static string
visitAll()
{
T1 param1;
T2 param2;
return _Fmt("-<%u%u>%s") % uint(param1)
% uint(param2)
% BASE::visitAll();
}
};
template<>
struct TestCase<void,void,Nil>
{
static string
visitAll()
{
return "-|";
}
};
typedef TestCase<void,void,Nil> IterationEnd;
} // (End) test data
/*********************************************************************//**
* @test check utilities for generating case combinations.
* - verify the Cartesian product is built properly
* - instantiate a two-parameter test template
* for all those cases, as given by the
* Cartesian product of two Type collections
*/
class GeneratorCombinations_test : public Test
{
virtual void
run (Arg)
{
checkCartesian();
checkCaseInstantiation();
}
void
checkCartesian ()
{
typedef CartesianProduct<Types1,Types2> Cartesian;
DISPLAY (Cartesian);
}
void
checkCaseInstantiation ()
{
using CombnationCases = InstantiateChainedCombinations< Types1,Types2
, TestCase
, IterationEnd >;
cout << "All-Test-Combinations-" << CombnationCases::visitAll() << endl;
}
};
/** Register this test class... */
LAUNCHER (GeneratorCombinations_test, "unit common");
}}} // namespace lib::meta::test