lumiera_/tests/vault/gear/scheduler-load-control-test.cpp

189 lines
5.7 KiB
C++
Raw Normal View History

/*
SchedulerLoadControl(Test) - verify scheduler load management facility
Copyright (C) Lumiera.org
2023, 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 scheduler-load-control-test.cpp
** unit test \ref SchedulerLoadControl_test
*/
#include "lib/test/run.hpp"
#include "vault/gear/load-controller.hpp"
//#include "lib/time/timevalue.hpp"
//#include "lib/format-cout.hpp"
//#include "lib/util.hpp"
//#include <utility>
using test::Test;
//using std::move;
//using util::isSameObject;
namespace vault{
namespace gear {
namespace test {
// using lib::time::FrameRate;
// using lib::time::Offset;
// using lib::time::Time;
using Capacity = LoadController::Capacity;
/*************************************************************************//**
* @test verify behaviour patterns relevant for Scheduler load control.
* @see SchedulerCommutator_test
* @see SchedulerService_test
* @see SchedulerStress_test
*/
class SchedulerLoadControl_test : public Test
{
virtual void
run (Arg)
{
simpleUsage();
classifyTimings();
tendNextActivity();
walkingDeadline();
setupLalup();
}
/** @test TODO demonstrate a simple usage scenario
* @todo WIP 10/23 🔁 define 🔁 implement
*/
void
simpleUsage()
{
BlockFlowAlloc bFlow;
LoadController ctrl{bFlow};
}
/** @test verify classification of time horizon for scheduling.
* - if the next planned Activity lies beyond the SLEEP_HORIZON,
* then the current thread can be considered part of the _idle capacity_
* - in a similar way, WORK_HORIZON delineates the zone of repeated incoming
* Activities from the zone considered part of current active operation
* - Activities within the NOW_HORIZON can be awaited by yield-spinning
* - and any event from current into the past will be scheduled right away
* @todo WIP 10/23 define implement
*/
void
classifyTimings()
{
Time next{0,10};
Time ut{1,0};
Time t1{0,9};
Time t2{next - SLEEP_HORIZON};
Time t21{t2 + ut};
Time t3{next - WORK_HORIZON};
Time t31{t3 + ut};
Time t4{next - NOW_HORIZON};
CHECK (Capacity::IDLETIME == LoadController::classifyCapacity (Offset{next - ut }));
CHECK (Capacity::IDLETIME == LoadController::classifyCapacity (Offset{next - t1 }));
CHECK (Capacity::WORKTIME == LoadController::classifyCapacity (Offset{next - t2 }));
CHECK (Capacity::WORKTIME == LoadController::classifyCapacity (Offset{next - t21}));
CHECK (Capacity::NEARTIME == LoadController::classifyCapacity (Offset{next - t3 }));
CHECK (Capacity::NEARTIME == LoadController::classifyCapacity (Offset{next - t31}));
CHECK (Capacity::SPINTIME == LoadController::classifyCapacity (Offset{next - t4 }));
CHECK (Capacity::DISPATCH == LoadController::classifyCapacity (Offset::ZERO ));
CHECK (Capacity::DISPATCH == LoadController::classifyCapacity (Offset{t4 - next }));
}
/** @test verify the mark for _tended next head_ Activity.
* @todo WIP 10/23 define implement
*/
void
tendNextActivity()
{
BlockFlowAlloc bFlow;
LoadController lctrl{bFlow};
Time t1{1,0};
Time t2{2,0};
Time t3{3,0};
CHECK (not lctrl.tendedNext (t2));
lctrl.tendNext (t2);
CHECK ( lctrl.tendedNext (t2));
CHECK (not lctrl.tendedNext (t3));
lctrl.tendNext (t3);
CHECK ( lctrl.tendedNext (t3));
// However — this is not a history memory...
CHECK (not lctrl.tendedNext (t1));
CHECK (not lctrl.tendedNext (t2));
CHECK ( lctrl.tendedNext (t3));
lctrl.tendNext (t1);
CHECK ( lctrl.tendedNext (t1));
CHECK (not lctrl.tendedNext (t2));
CHECK (not lctrl.tendedNext (t3));
lctrl.tendNext (t2);
CHECK (not lctrl.tendedNext (t1));
CHECK ( lctrl.tendedNext (t2));
CHECK (not lctrl.tendedNext (t3));
}
/** @test TODO
* @todo WIP 10/23 🔁 define implement
*/
void
walkingDeadline()
{
UNIMPLEMENTED ("walking Deadline");
}
/** @test TODO
* @todo WIP 10/23 🔁 define implement
*/
void
setupLalup()
{
}
};
/** Register this test class... */
LAUNCHER (SchedulerLoadControl_test, "unit engine");
}}} // namespace vault::gear::test