/** * @file test_signal_executor.cpp * * @date Nov 28, 2013 * @author Andrey Belomutskiy, (c) 2012-2015 */ #include #include "main.h" #include "signal_executor.h" #include "test_signal_executor.h" #include "io_pins.h" #include "utlist.h" #include "event_queue.h" static io_pin_e testLastToggledPin; static int testToggleCounter; void setOutputPinValue(io_pin_e pin, int value) { // this is a test implementation of the method - we use it to see what's going on testLastToggledPin = pin; testToggleCounter++; } EventQueue schedulingQueue; void scheduleTask(const char *msg, scheduling_s *scheduling, int delayUs, schfunc_t callback, void *param) { schedulingQueue.insertTask(scheduling, getTimeNowUs() + delayUs, callback, param); } void scheduleTask2(const char *prefix, scheduling_s *scheduling, uint64_t time, schfunc_t callback, void *param) { firmwareError("not implemented"); //schedulingQueue.insertTask(scheduling, getTimeNowUs() + delayUs, callback, param); } void initSignalExecutorImpl(void) { } static EventQueue eq; static int callbackCounter = 0; static void callback(void *a) { callbackCounter++; } static int complexTestNow; typedef struct { scheduling_s s; int period; } TestPwm; static void complexCallback(TestPwm *testPwm) { callbackCounter++; eq.insertTask(&testPwm->s, complexTestNow + testPwm->period, (schfunc_t)complexCallback, testPwm); } static void testSignalExecutor2(void) { print("*************************************** testSignalExecutor2\r\n"); eq.clear(); TestPwm p1; TestPwm p2; p1.period = 2; p2.period = 3; complexTestNow = 0; callbackCounter = 0; eq.insertTask(&p1.s, 0, (schfunc_t)complexCallback, &p1); eq.insertTask(&p2.s, 0, (schfunc_t)complexCallback, &p2); eq.executeAll(complexTestNow); assertEqualsM("callbackCounter #1", 2, callbackCounter); assertEquals(2, eq.size()); eq.executeAll(complexTestNow = 2); assertEqualsM("callbackCounter #2", 3, callbackCounter); assertEquals(2, eq.size()); eq.executeAll(complexTestNow = 3); assertEqualsM("callbackCounter #3", 4, callbackCounter); assertEquals(2, eq.size()); } void testSignalExecutor(void) { print("*************************************** testSignalExecutor\r\n"); assertEquals(EMPTY_QUEUE, eq.getNextEventTime(0)); scheduling_s s1; scheduling_s s2; scheduling_s s3; eq.insertTask(&s1, 10, callback, NULL); eq.insertTask(&s2, 11, callback, NULL); eq.insertTask(&s3, 12, callback, NULL); callbackCounter = 0; eq.executeAll(10); assertEquals(1, callbackCounter); callbackCounter = 0; eq.executeAll(11); assertEquals(1, callbackCounter); eq.clear(); eq.insertTask(&s1, 12, callback, NULL); eq.insertTask(&s2, 11, callback, NULL); eq.insertTask(&s3, 10, callback, NULL); callbackCounter = 0; eq.executeAll(10); assertEquals(1, callbackCounter); callbackCounter = 0; eq.executeAll(11); assertEquals(1, callbackCounter); eq.clear(); callbackCounter = 0; eq.insertTask(&s1, 10, callback, NULL); assertEquals(10, eq.getNextEventTime(0)); eq.executeAll(1); assertEqualsM("callbacks not expected", 0, callbackCounter); eq.executeAll(11); assertEquals(1, callbackCounter); assertEquals(EMPTY_QUEUE, eq.getNextEventTime(0)); eq.insertTask(&s1, 10, callback, NULL); eq.insertTask(&s2, 13, callback, NULL); assertEquals(10, eq.getNextEventTime(0)); eq.executeAll(1); assertEquals(10, eq.getNextEventTime(0)); eq.clear(); callbackCounter = 0; // both events are scheduled for the same time eq.insertTask(&s1, 10, callback, NULL); eq.insertTask(&s2, 10, callback, NULL); eq.executeAll(11); assertEquals(2, callbackCounter); testSignalExecutor2(); }