/* SchedulerLoadControl(Test) - verify scheduler load management facility Copyright (C) Lumiera.org 2023, 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. * *****************************************************/ /** @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 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(); 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() { BlockFlowAlloc bFlow; LoadController ctrl{bFlow}; 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 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