fsfw/tests/src/fsfw_tests/unit/osal/TestSemaphore.cpp

47 lines
1.6 KiB
C++
Raw Normal View History

2020-10-20 17:11:23 +02:00
#ifdef LINUX
/*
#include <fsfw/tasks/SemaphoreFactory.h>
#include <fsfw/timemanager/Stopwatch.h>
2022-02-02 10:29:30 +01:00
#include "catch.hpp"
#include "core/CatchDefinitions.h"
2020-10-20 17:11:23 +02:00
TEST_CASE("Binary Semaphore Test" , "[BinSemaphore]") {
2022-02-02 10:29:30 +01:00
//perform set-up here
SemaphoreIF* binSemaph = SemaphoreFactory::instance()->
createBinarySemaphore();
REQUIRE(binSemaph != nullptr);
SECTION("Simple Test") {
// set-up is run for each section
REQUIRE(binSemaph->getSemaphoreCounter() == 1);
REQUIRE(binSemaph->release() ==
static_cast<int>(SemaphoreIF::SEMAPHORE_NOT_OWNED));
REQUIRE(binSemaph->acquire(SemaphoreIF::POLLING) ==
retval::CATCH_OK);
{
// not precise enough on linux.. should use clock instead..
//Stopwatch stopwatch(false);
//REQUIRE(binSemaph->acquire(SemaphoreIF::TimeoutType::WAITING, 5) ==
// SemaphoreIF::SEMAPHORE_TIMEOUT);
//dur_millis_t time = stopwatch.stop();
//CHECK(time == 5);
}
REQUIRE(binSemaph->getSemaphoreCounter() == 0);
REQUIRE(binSemaph->release() == retval::CATCH_OK);
}
SemaphoreFactory::instance()->deleteSemaphore(binSemaph);
// perform tear-down here
2020-10-20 17:11:23 +02:00
}
TEST_CASE("Counting Semaphore Test" , "[CountingSemaph]") {
2022-02-02 10:29:30 +01:00
SECTION("Simple Test") {
2020-10-20 17:11:23 +02:00
2022-02-02 10:29:30 +01:00
}
2020-10-20 17:11:23 +02:00
}
*/
#endif