/* TimeControl(Test) - mutating time entities with life connection and feedback Copyright (C) Lumiera.org 2011, Hermann Vosseler This program 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. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * *****************************************************/ #include "lib/test/run.hpp" #include "lib/test/test-helper.hpp" #include "lib/time/timevalue.hpp" #include "lib/time/timequant.hpp" #include "lib/time/mutation.hpp" #include "proc/asset/meta/time-grid.hpp" #include "lib/meta/typelist.hpp" #include "lib/util.hpp" #include #include #include using boost::lexical_cast; using util::isnil; using std::cout; using std::endl; using std::string; namespace lib { namespace time{ namespace test{ using asset::meta::TimeGrid; using lumiera::typelist::Types; using lumiera::typelist::InstantiateForEach; namespace { inline string pop (Arg arg) { if (isnil (arg)) return ""; string entry = arg[0]; arg.erase (arg.begin()); return entry; } } /**************************************************************** * @test use the time::Control to push a sequence of modifications * to various time entities; in all cases, a suitable change * should be imposed to the target and then a notification signal * should be invoked. * @todo cover the cases..... * - change to a given value * - change by an offset * - change using a grid value * - apply an (grid) increment */ class TimeControl_test : public Test { gavl_time_t random_or_get (string arg) { if (isnil(arg)) return gavl_time_t (1 + (rand() % 100000)) * GAVL_TIME_SCALE; else return lexical_cast (arg); } struct TestValues { TimeVar var; Duration dur; TimeSpan span; QuTime quant; TestValues (TimeValue o) : var(o) , dur(o) , span(o, Offset(o)) , quant(o, "test_grid") { } }; virtual void run (Arg arg) { TimeValue o (random_or_get (pop(arg))); TimeValue c (random_or_get (pop(arg))); CHECK (o != c, "unsuitable testdata"); // using a 25fps-grid, but with an time origin offset by 1/50sec TimeGrid::build("test_grid", FrameRate::PAL, Time(FSecs(1,50))); QuTime qChange (c, "test_grid"); FrameNr count(qChange); verifyBasics(); verifyMatrix_of_MutationCases(); } void verifyBasics() { } template struct TestCase4Target { void performTestCases() { } }; void verifyMatrix_of_MutationCases () { typedef Types KindsOfTarget; typedef InstantiateForEach TestMatrix; TestMatrix().performTestCases(); } }; /** Register this test class... */ LAUNCHER (TimeControl_test, "unit common"); }}} // namespace lib::time::test