mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-02-18 10:53:17 +00:00
* **New Features** * Plugin-style modules for platforms and devices with start/stop lifecycle and a runtime-consumable device tree array. * **Refactor** * Consolidated initialization into a kernel/module startup flow. * Generated devicetree artifacts moved to the build Generated directory. * **Changes** * Removed legacy no-op registration hooks and I2C lock/unlock wrappers. * Driver ownership and private state moved to explicit module/owner model. * Added ERROR_NOT_ALLOWED error code.
74 lines
2.2 KiB
C++
74 lines
2.2 KiB
C++
#include "doctest.h"
|
|
|
|
#include <tactility/driver.h>
|
|
#include <tactility/module.h>
|
|
|
|
static Module module = {
|
|
.name = "test_module",
|
|
.start = nullptr,
|
|
.stop = nullptr
|
|
};
|
|
|
|
TEST_CASE("driver_construct and driver_destruct should set and unset the correct fields") {
|
|
Driver driver = { 0 };
|
|
driver.owner = &module;
|
|
|
|
CHECK_EQ(driver_construct(&driver), ERROR_NONE);
|
|
CHECK_NE(driver.driver_private, nullptr);
|
|
CHECK_EQ(driver_destruct(&driver), ERROR_NONE);
|
|
CHECK_EQ(driver.driver_private, nullptr);
|
|
}
|
|
|
|
TEST_CASE("a driver without a module should not be destructible") {
|
|
Driver driver = { 0 };
|
|
|
|
CHECK_EQ(driver_construct(&driver), ERROR_NONE);
|
|
CHECK_EQ(driver_destruct(&driver), ERROR_NOT_ALLOWED);
|
|
driver.owner = &module;
|
|
CHECK_EQ(driver_destruct(&driver), ERROR_NONE);
|
|
}
|
|
|
|
TEST_CASE("driver_is_compatible should return true if a compatible value is found") {
|
|
const char* compatible[] = { "test_compatible", nullptr };
|
|
Driver driver = {
|
|
.name = "test_driver",
|
|
.compatible = compatible,
|
|
.startDevice = nullptr,
|
|
.stopDevice = nullptr,
|
|
.api = nullptr,
|
|
.deviceType = nullptr,
|
|
.owner = &module,
|
|
.driver_private = nullptr
|
|
};
|
|
CHECK_EQ(driver_is_compatible(&driver, "test_compatible"), true);
|
|
CHECK_EQ(driver_is_compatible(&driver, "nope"), false);
|
|
CHECK_EQ(driver_is_compatible(&driver, nullptr), false);
|
|
}
|
|
|
|
TEST_CASE("driver_find should only find a compatible driver when the driver was constructed") {
|
|
const char* compatible[] = { "test_compatible", nullptr };
|
|
Driver driver = {
|
|
.name = "test_driver",
|
|
.compatible = compatible,
|
|
.startDevice = nullptr,
|
|
.stopDevice = nullptr,
|
|
.api = nullptr,
|
|
.deviceType = nullptr,
|
|
.owner = &module,
|
|
.driver_private = nullptr
|
|
};
|
|
|
|
Driver* found_driver = driver_find_compatible("test_compatible");
|
|
CHECK_EQ(found_driver, nullptr);
|
|
|
|
CHECK_EQ(driver_construct(&driver), ERROR_NONE);
|
|
|
|
found_driver = driver_find_compatible("test_compatible");
|
|
CHECK_EQ(found_driver, &driver);
|
|
|
|
CHECK_EQ(driver_destruct(&driver), ERROR_NONE);
|
|
|
|
found_driver = driver_find_compatible("test_compatible");
|
|
CHECK_EQ(found_driver, nullptr);
|
|
}
|