/* * Copyright (C) 2015 Nick van IJzendoorn * 2017 HAW Hamburg * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @ingroup tests * @{ * * @file * @brief Thread test application * * @author Nick van IJzendoorn * @author Sebastian Meiling * * @} */ #include #include #include "log.h" #include "msg.h" #include "test_utils/interactive_sync.h" #define MSG_QUEUE_LENGTH (8) msg_t msg_queue[MSG_QUEUE_LENGTH]; int main(void) { test_utils_interactive_sync(); msg_t msges[MSG_QUEUE_LENGTH]; msg_init_queue(msg_queue, MSG_QUEUE_LENGTH); puts("[START]"); /* add message to own queue */ for (int idx = 0; idx < MSG_QUEUE_LENGTH; ++idx) { msges[idx].type = idx; msg_send_to_self(msges + idx); LOG_INFO("+ add msg: %d\n", idx); if (msg_avail() != (idx) + 1) { puts("[FAILED]"); return 1; } } /* receive available messages in queue */ for (int idx = msg_avail(); idx > 0; --idx) { msg_t msg; msg_receive(&msg); LOG_INFO("- got msg: %d\n", (MSG_QUEUE_LENGTH - idx)); if ((int)msg.type != (MSG_QUEUE_LENGTH - idx) || msg_avail() != idx - 1) { puts("[FAILED]"); return 1; } } puts("[SUCCESS]"); return 0; }