tests/ztimer_mutex_lock_timeout: new test
This commit is contained in:
parent
d48fac278b
commit
aa4532a2e7
5
tests/ztimer_mutex_lock_timeout/Makefile
Normal file
5
tests/ztimer_mutex_lock_timeout/Makefile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
include ../Makefile.tests_common
|
||||||
|
|
||||||
|
USEMODULE += ztimer_usec
|
||||||
|
|
||||||
|
include $(RIOTBASE)/Makefile.include
|
||||||
95
tests/ztimer_mutex_lock_timeout/main.c
Normal file
95
tests/ztimer_mutex_lock_timeout/main.c
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 Otto-von-Guericke-Universität Magdeburg
|
||||||
|
*
|
||||||
|
* 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 Test application for testing ztimer_mutex_lock_timeout_timeout
|
||||||
|
*
|
||||||
|
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include "mutex.h"
|
||||||
|
#include "test_utils/expect.h"
|
||||||
|
#include "timex.h"
|
||||||
|
#include "ztimer.h"
|
||||||
|
|
||||||
|
#ifndef TEST_CLOCK
|
||||||
|
#define TEST_CLOCK ZTIMER_USEC
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef TIMEOUT_SMALL
|
||||||
|
#define TIMEOUT_SMALL (100U)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef TIMEOUT_LARGE
|
||||||
|
#define TIMEOUT_LARGE (US_PER_SEC / 2)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static mutex_t testlock = MUTEX_INIT;
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
ztimer_now_t pre, post;
|
||||||
|
puts(
|
||||||
|
"Test Application for ztimer_mutex_lock_timeout_timeout()\n"
|
||||||
|
"================================================\n"
|
||||||
|
);
|
||||||
|
|
||||||
|
printf("%s: ", "Test on unlocked mutex with zero timeout");
|
||||||
|
expect(ztimer_mutex_lock_timeout(TEST_CLOCK, &testlock, 0) == 0);
|
||||||
|
puts("OK");
|
||||||
|
|
||||||
|
printf("%s: ", "Test on unlocked mutex with small timeout");
|
||||||
|
mutex_unlock(&testlock);
|
||||||
|
expect(ztimer_mutex_lock_timeout(TEST_CLOCK, &testlock, TIMEOUT_SMALL) == 0);
|
||||||
|
puts("OK");
|
||||||
|
|
||||||
|
printf("%s: ", "Test on unlocked mutex with large timeout");
|
||||||
|
mutex_unlock(&testlock);
|
||||||
|
pre = ztimer_now(TEST_CLOCK);
|
||||||
|
expect(ztimer_mutex_lock_timeout(TEST_CLOCK, &testlock, US_PER_SEC / 2) == 0);
|
||||||
|
post = ztimer_now(TEST_CLOCK);
|
||||||
|
/* Call shouldn't block on unlocked mutex. So the duration spent on the
|
||||||
|
* function call should be short. Let's take a very generous definition of
|
||||||
|
* "short duration" here to not get false failures on slow boards */
|
||||||
|
expect(post - pre < TIMEOUT_LARGE);
|
||||||
|
puts("OK");
|
||||||
|
|
||||||
|
printf("%s: ", "Test on locked mutex with zero timeout");
|
||||||
|
pre = ztimer_now(TEST_CLOCK);
|
||||||
|
expect(ztimer_mutex_lock_timeout(TEST_CLOCK, &testlock, 0) == -ECANCELED);
|
||||||
|
post = ztimer_now(TEST_CLOCK);
|
||||||
|
expect(post - pre < TIMEOUT_LARGE);
|
||||||
|
puts("OK");
|
||||||
|
|
||||||
|
printf("%s: ", "Test on locked mutex with small timeout");
|
||||||
|
pre = ztimer_now(TEST_CLOCK);
|
||||||
|
expect(ztimer_mutex_lock_timeout(TEST_CLOCK, &testlock, TIMEOUT_SMALL) == -ECANCELED);
|
||||||
|
post = ztimer_now(TEST_CLOCK);
|
||||||
|
expect((post - pre > TIMEOUT_SMALL) && (post - pre < TIMEOUT_LARGE));
|
||||||
|
puts("OK");
|
||||||
|
|
||||||
|
printf("%s: ", "Test on locked mutex with large timeout");
|
||||||
|
pre = ztimer_now(TEST_CLOCK);
|
||||||
|
expect(ztimer_mutex_lock_timeout(TEST_CLOCK, &testlock, TIMEOUT_LARGE) == -ECANCELED);
|
||||||
|
post = ztimer_now(TEST_CLOCK);
|
||||||
|
expect(post - pre > TIMEOUT_LARGE);
|
||||||
|
puts("OK");
|
||||||
|
|
||||||
|
|
||||||
|
puts("TEST PASSED");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
20
tests/ztimer_mutex_lock_timeout/tests/01-run.py
Executable file
20
tests/ztimer_mutex_lock_timeout/tests/01-run.py
Executable file
@ -0,0 +1,20 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
# Copyright (C) 2020 Otto-von-Guericke-Universität Magdeburg
|
||||||
|
#
|
||||||
|
# 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 Marian Buschsieweke <marian.buschsieweke@ovgu.de>
|
||||||
|
|
||||||
|
import sys
|
||||||
|
from testrunner import run
|
||||||
|
|
||||||
|
|
||||||
|
def testfunc(child):
|
||||||
|
child.expect("TEST PASSED")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
sys.exit(run(testfunc))
|
||||||
Loading…
x
Reference in New Issue
Block a user