/** * @file test_signal_executor.cpp * * @date Nov 28, 2013 * @author Andrey Belomutskiy, (c) 2012-2020 */ #include "pch.h" #include "event_queue.h" static int callbackCounter = 0; static void callback(void *a) { callbackCounter++; } static int complexTestNow; struct TestPwm { TestPwm(EventQueue *eventQueue) { this->eventQueue = eventQueue; } scheduling_s s; int period; EventQueue *eventQueue; }; static void complexCallback(TestPwm *testPwm) { callbackCounter++; testPwm->eventQueue->insertTask(&testPwm->s, complexTestNow + testPwm->period, { complexCallback, testPwm }); } TEST(misc, testSignalExecutor2) { EventQueue eq; TestPwm p1(&eq); TestPwm p2(&eq); p1.period = 2; p2.period = 3; complexTestNow = 0; callbackCounter = 0; eq.insertTask(&p1.s, 0, { complexCallback, &p1 }); eq.insertTask(&p2.s, 0, { complexCallback, &p2 }); eq.executeAll(complexTestNow); ASSERT_EQ( 2, callbackCounter) << "callbackCounter #1"; ASSERT_EQ(2, eq.size()); eq.executeAll(complexTestNow = 2); ASSERT_EQ( 3, callbackCounter) << "callbackCounter #2"; ASSERT_EQ(2, eq.size()); eq.executeAll(complexTestNow = 3); ASSERT_EQ( 4, callbackCounter) << "callbackCounter #3"; ASSERT_EQ(2, eq.size()); } static long prevValue = -1; static void orderCallback(void *a) { long value = (long)a; printf("value=%d prevValue=%d\r\n", value, prevValue); ASSERT_TRUE(value > prevValue) << "orderCallback"; prevValue = value; } TEST(misc, testSignalExecutor3) { EventQueue eq; scheduling_s s1; scheduling_s s2; scheduling_s s3; eq.insertTask(&s1, 10, { orderCallback, (void*)1 }); eq.insertTask(&s2, 11, { orderCallback, (void*)2 }); eq.insertTask(&s3, 12, { orderCallback, (void*)3 }); eq.executeAll(100); } TEST(misc, testSignalExecutor) { EventQueue eq; ASSERT_EQ(eq.getNextEventTime(0), unexpected); scheduling_s s1; scheduling_s s2; scheduling_s s3; scheduling_s s4; eq.insertTask(&s1, 10, callback); eq.insertTask(&s4, 10, callback); eq.insertTask(&s3, 12, callback); eq.insertTask(&s2, 11, callback); ASSERT_EQ(4, eq.size()); ASSERT_EQ(10, eq.getHead()->momentX); ASSERT_EQ(10, eq.getHead()->nextScheduling_s->momentX); ASSERT_EQ(11, eq.getHead()->nextScheduling_s->nextScheduling_s->momentX); ASSERT_EQ(12, eq.getHead()->nextScheduling_s->nextScheduling_s->nextScheduling_s->momentX); callbackCounter = 0; eq.executeAll(10); ASSERT_EQ( 2, callbackCounter) << "callbackCounter/2"; callbackCounter = 0; eq.executeAll(11); ASSERT_EQ( 1, callbackCounter) << "callbackCounter/1#1"; eq.executeAll(100); ASSERT_EQ(0, eq.size()); eq.insertTask(&s1, 12, callback); eq.insertTask(&s2, 11, callback); eq.insertTask(&s3, 10, callback); callbackCounter = 0; eq.executeAll(10); ASSERT_EQ( 1, callbackCounter) << "callbackCounter/1#2"; callbackCounter = 0; eq.executeAll(11); ASSERT_EQ(1, callbackCounter); eq.executeAll(100); ASSERT_EQ(0, eq.size()); callbackCounter = 0; eq.insertTask(&s1, 10, callback); ASSERT_EQ(10, eq.getNextEventTime(0).value_or(-1)); eq.executeAll(1); ASSERT_EQ( 0, callbackCounter) << "callbacks not expected"; eq.executeAll(11); ASSERT_EQ(1, callbackCounter); ASSERT_EQ(eq.getNextEventTime(0), unexpected); eq.insertTask(&s1, 10, callback); eq.insertTask(&s2, 13, callback); ASSERT_EQ(10, eq.getNextEventTime(0).value_or(-1)); eq.executeAll(1); ASSERT_EQ(10, eq.getNextEventTime(0).value_or(-1)); eq.executeAll(100); ASSERT_EQ(0, eq.size()); callbackCounter = 0; // both events are scheduled for the same time eq.insertTask(&s1, 10, callback); eq.insertTask(&s2, 10, callback); eq.executeAll(11); ASSERT_EQ(2, callbackCounter); }