...hard to tackle... The idea is to wrap the TreeExplorer builder, so that our specific builder functions can delegated to the (inherited) generic builder functions and would just need to supply some cleverly bound lambdas. However, resulting types are recursive, which does not play nice with type inference, and working around that problem leads to capturing a self reference, which at time of invocation is already invalidated (due to moving the whole pipeline into the final storage)
147 lines
4.4 KiB
C++
147 lines
4.4 KiB
C++
/*
|
|
Timings(Test) - document and verify basic frame step timings
|
|
|
|
Copyright (C) Lumiera.org
|
|
2012, Hermann Vosseler <Ichthyostega@web.de>
|
|
|
|
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.
|
|
|
|
* *****************************************************/
|
|
|
|
/** @file dispatcher-interface-test.cpp
|
|
** unit test \ref Timings_test
|
|
**
|
|
** @warning as of 5/2023 planning-chunk generation is reworked ///////////////////////////////////////////TICKET #1301 : factor out RenderDrive
|
|
*/
|
|
|
|
|
|
#include "lib/test/run.hpp"
|
|
#include "lib/test/test-helper.hpp"
|
|
|
|
#include "steam/play/timings.hpp"
|
|
#include "lib/time/timevalue.hpp"
|
|
//#include "lib/time/timequant.hpp"
|
|
//#include "lib/format-cout.hpp"
|
|
//#include "lib/util-coll.hpp"
|
|
#include "lib/util.hpp"
|
|
|
|
//#include <functional>
|
|
//#include <vector>
|
|
|
|
using test::Test;
|
|
using util::isnil;
|
|
//using std::vector;
|
|
//using std::function;
|
|
using std::rand;
|
|
|
|
|
|
namespace steam {
|
|
namespace engine{
|
|
namespace test {
|
|
|
|
using lib::time::FSecs;
|
|
using lib::time::FrameCnt;
|
|
using lib::time::FrameRate;
|
|
using lib::time::Duration;
|
|
using lib::time::Offset;
|
|
using lib::time::Time;
|
|
using play::Timings;
|
|
|
|
namespace { // Test fixture...
|
|
|
|
/* == test parameters == */
|
|
|
|
const uint START_FRAME(10);
|
|
|
|
const uint DUMMY_CHANNEL(0); /////////////////////////////////////////////////////////////TICKET #1297 : get rid of the channels (use different ModelPort)
|
|
|
|
|
|
|
|
|
|
FSecs
|
|
randTicks()
|
|
{
|
|
return FSecs{1 + rand() % 600, 1 + rand() % 600};
|
|
}
|
|
|
|
} // (End) Test fixture
|
|
|
|
#if false /////////////////////////////////////////////////////////////////////////////////////////////////////////////UNIMPLEMENTED :: TICKET #1301
|
|
#endif /////////////////////////////////////////////////////////////////////////////////////////////////////////////UNIMPLEMENTED :: TICKET #1301
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***************************************************************//**
|
|
* @test document and verify frame timing calculations, which are
|
|
* used in the Player / engine::Dispatcher, to translate a CalcStream
|
|
* into individual node jobs.
|
|
* @see TimingConstraints_test
|
|
*/
|
|
class Timings_test : public Test
|
|
{
|
|
|
|
virtual void
|
|
run (Arg)
|
|
{
|
|
verify_simpleFrameStep();
|
|
verify_next_startPoint();
|
|
}
|
|
|
|
|
|
/** @test perform the basic dispatch step
|
|
* and verify the generated frame coordinates
|
|
*/
|
|
void
|
|
verify_simpleFrameStep()
|
|
{
|
|
Timings timings (FrameRate::PAL);
|
|
CHECK (timings.getOrigin() == Time::ZERO);
|
|
|
|
ENSURE (START_FRAME == 10);
|
|
CHECK (timings.getFrameStartAt(START_FRAME) == Time::ZERO + Duration(10, FrameRate::PAL));
|
|
CHECK (timings.getFrameStartAt(START_FRAME+1) == Time::ZERO + Duration(11, FrameRate::PAL));
|
|
#if false /////////////////////////////////////////////////////////////////////////////////////////////////////////////UNIMPLEMENTED :: TICKET #1301
|
|
#endif /////////////////////////////////////////////////////////////////////////////////////////////////////////////UNIMPLEMENTED :: TICKET #1301
|
|
}
|
|
|
|
|
|
/** @test detect boundaries of frame planning chunks for arbitrary chunk duration.
|
|
*/
|
|
void
|
|
verify_next_startPoint()
|
|
{
|
|
Timings timings (FrameRate::PAL);
|
|
Time refPoint{randTicks()};
|
|
|
|
FrameCnt startFrame = timings.getBreakPointAfter (refPoint);
|
|
Time frameStart = timings.getFrameStartAt(startFrame);
|
|
|
|
Duration frameDuration (1, FrameRate::PAL);
|
|
|
|
CHECK (frameStart >= refPoint);
|
|
CHECK (frameStart < refPoint + frameDuration);
|
|
}
|
|
};
|
|
|
|
|
|
/** Register this test class... */
|
|
LAUNCHER (Timings_test, "unit engine");
|
|
|
|
|
|
|
|
}}} // namespace steam::engine::test
|