mirror of
https://github.com/mudita/MuditaOS.git
synced 2026-04-19 14:40:57 -04:00
To be able to pair properly using SSP the BT device have to know which services we're running, thus we need to register SDP entries after startup of the BT stack
187 lines
5.8 KiB
C++
187 lines
5.8 KiB
C++
// Copyright (c) 2017-2021, Mudita Sp. z.o.o. All rights reserved.
|
|
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
|
|
|
|
#include <catch2/catch.hpp>
|
|
|
|
#include "WorkerController.hpp"
|
|
|
|
using namespace bluetooth;
|
|
|
|
class DriverMock : public AbstractDriver
|
|
{
|
|
public:
|
|
Error::Code init() override
|
|
{
|
|
return initReturnCode;
|
|
}
|
|
Error::Code run() override
|
|
{
|
|
return runReturnCode;
|
|
}
|
|
Error::Code stop() override
|
|
{
|
|
return stopReturnCode;
|
|
}
|
|
Error scan() override
|
|
{
|
|
return Error::Success;
|
|
}
|
|
void stopScan() override
|
|
{}
|
|
void setVisibility(bool visibility) override
|
|
{}
|
|
bool pair(Devicei device, std::uint8_t protectionLevel = 0) override
|
|
{
|
|
return true;
|
|
}
|
|
bool unpair(Devicei device) override
|
|
{
|
|
return true;
|
|
}
|
|
void registerErrorCallback(const ErrorCallback &) override
|
|
{}
|
|
void registerPowerOnCallback(const PowerOnCallback &) override
|
|
{}
|
|
|
|
Error::Code initReturnCode = Error::Success;
|
|
Error::Code runReturnCode = Error::Success;
|
|
Error::Code stopReturnCode = Error::Success;
|
|
};
|
|
|
|
auto InitializerMock = []() { return Error::Success; };
|
|
|
|
class HandlerMock : public AbstractCommandHandler
|
|
{
|
|
public:
|
|
Error::Code handle(Command command) override
|
|
{
|
|
return returnCode;
|
|
}
|
|
|
|
Error::Code returnCode = Error::Success;
|
|
};
|
|
|
|
TEST_CASE("Given StatefulController when turn on then turned on")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when error during device registration then turned off")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), []() { return Error::SystemError; }};
|
|
controller.turnOn();
|
|
REQUIRE(!controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when error during driver init then turned off")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
driver->initReturnCode = Error::SystemError;
|
|
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(!controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when error during driver run then turned off")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
driver->runReturnCode = Error::SystemError;
|
|
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(!controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when restart then don't init twice")
|
|
{
|
|
auto driver = std::make_shared<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{driver, std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
|
|
controller.turnOff();
|
|
REQUIRE(!controller.isOn());
|
|
|
|
driver->initReturnCode = Error::SystemError;
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when turn off in off state then turned off")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOff();
|
|
REQUIRE(!controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when turn off in on state then turned off")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
|
|
controller.turnOff();
|
|
REQUIRE(!controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when shutdown in off state then terminated")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.shutdown();
|
|
REQUIRE(controller.isTerminated());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when shutdown in on state then terminated")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
|
|
controller.shutdown();
|
|
REQUIRE(controller.isTerminated());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when process command successfully then turned on")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
|
|
controller.processCommand(bluetooth::Command(Command::Type::PowerOn));
|
|
REQUIRE(controller.isOn());
|
|
}
|
|
|
|
TEST_CASE("Given StatefulController when processing command failed then restarted and turned on")
|
|
{
|
|
auto driver = std::make_unique<DriverMock>();
|
|
auto processor = std::make_unique<HandlerMock>();
|
|
processor->returnCode = Error::SystemError;
|
|
StatefulController controller{std::move(driver), std::move(processor), InitializerMock};
|
|
controller.turnOn();
|
|
REQUIRE(controller.isOn());
|
|
|
|
controller.processCommand(bluetooth::Command(Command::Type::PowerOn));
|
|
controller.processCommand(bluetooth::Command(Command::Type::PowerOn));
|
|
REQUIRE(controller.isOn());
|
|
}
|