Merge pull request #11679 from JulianHolzwarth/pr/xtimer_mutex_lock_timeout/first_tests

tests/xtimer_mutex_lock_timeout: add simple case test
This commit is contained in:
Gaëtan Harter 2019-06-26 16:27:39 +02:00 committed by GitHub
commit eab0a88642
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 179 additions and 1 deletions

View File

@ -38,10 +38,14 @@
#define ENABLE_DEBUG 0
#include "debug.h"
/*
* @brief: struct for mutex lock with timeout
* xtimer_mutex_lock_timeout() uses it to give information to the timer callback function
*/
typedef struct {
mutex_t *mutex;
thread_t *thread;
int timeout;
volatile int timeout;
} mutex_thread_t;
static void _callback_unlock_mutex(void* arg)

View File

@ -0,0 +1,8 @@
include ../Makefile.tests_common
USEMODULE += xtimer
USEMODULE += shell
TEST_ON_CI_WHITELIST += all
include $(RIOTBASE)/Makefile.include

View File

@ -0,0 +1,133 @@
/*
* Copyright (C) 2019 Freie Universität Berlin,
*
* 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 testing xtimer_mutex_lock_timeout function
*
*
* @author Julian Holzwarth <julian.holzwarth@fu-berlin.de>
*
*/
#include <stdio.h>
#include <stdlib.h>
#include "shell.h"
#include "xtimer.h"
/* timeout at one millisecond (1000 us) to make sure it does not spin. */
#define LONG_MUTEX_TIMEOUT 1000
/**
* Foward declarations
*/
static int cmd_test_xtimer_mutex_lock_timeout_long_unlocked(int argc,
char **argv);
static int cmd_test_xtimer_mutex_lock_timeout_long_locked(int argc,
char **argv);
/**
* @brief List of command for this application.
*/
static const shell_command_t shell_commands[] = {
{ "mutex_timeout_long_unlocked", "unlocked mutex with long timeout",
cmd_test_xtimer_mutex_lock_timeout_long_unlocked, },
{ "mutex_timeout_long_locked", "locked mutex with long timeout",
cmd_test_xtimer_mutex_lock_timeout_long_locked, },
{ NULL, NULL, NULL }
};
/**
* @brief shell command to test xtimer_mutex_lock_timeout
*
* the mutex is not locked before the function call and
* the timer long. Meaning the timer will get removed
* before triggering.
*
* @param[in] argc Number of arguments
* @param[in] argv Array of arguments
*
* @return 0 on success
*/
static int cmd_test_xtimer_mutex_lock_timeout_long_unlocked(int argc,
char **argv)
{
(void)argc;
(void)argv;
puts("starting test: xtimer mutex lock timeout");
mutex_t test_mutex = MUTEX_INIT;
if (xtimer_mutex_lock_timeout(&test_mutex, LONG_MUTEX_TIMEOUT) == 0) {
/* mutex has to be locked */
if (mutex_trylock(&test_mutex) == 0) {
puts("OK");
}
else {
puts("error mutex not locked");
}
}
else {
puts("error: mutex timed out");
}
return 0;
}
/**
* @brief shell command to test xtimer_mutex_lock_timeout
*
* the mutex is locked before the function call and
* the timer long. Meaning the timer will trigger
* and remove the thread from the mutex waiting list.
*
* @param[in] argc Number of arguments
* @param[in] argv Array of arguments
*
* @return 0 on success
*/
static int cmd_test_xtimer_mutex_lock_timeout_long_locked(int argc,
char **argv)
{
(void)argc;
(void)argv;
puts("starting test: xtimer mutex lock timeout");
mutex_t test_mutex = MUTEX_INIT;
mutex_lock(&test_mutex);
if (xtimer_mutex_lock_timeout(&test_mutex, LONG_MUTEX_TIMEOUT) == 0) {
puts("Error: mutex taken");
}
else {
/* mutex has to be locked */
if (mutex_trylock(&test_mutex) == 0) {
puts("OK");
}
else {
puts("error mutex not locked");
}
}
return 0;
}
/**
* @brief main function starting shell
*
* @return 0 on success
*/
int main(void)
{
puts("Starting shell...");
char line_buf[SHELL_DEFAULT_BUFSIZE];
shell_run(shell_commands, line_buf, SHELL_DEFAULT_BUFSIZE);
return 0;
}

View File

@ -0,0 +1,33 @@
#!/usr/bin/env python3
# Copyright (C) 2019 Freie Universität Berlin,
#
# 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.
# @author Julian Holzwarth <julian.holzwarth@fu-berlin.de>
import sys
import pexpect
from testrunner import run
def testfunc(child):
# Try to wait for the shell
for _ in range(0, 10):
child.sendline("help")
if child.expect_exact(["> ", pexpect.TIMEOUT], timeout=1) == 0:
break
child.sendline("mutex_timeout_long_unlocked")
child.expect("starting test: xtimer mutex lock timeout")
child.expect("OK")
child.expect_exact("> ")
child.sendline("mutex_timeout_long_locked")
child.expect("starting test: xtimer mutex lock timeout")
child.expect("OK")
child.expect_exact("> ")
if __name__ == "__main__":
sys.exit(run(testfunc))