-
Notifications
You must be signed in to change notification settings - Fork 0
Home
This page provides an overview of three core header files within the UT (Unit Testing) framework:
- ut_control_plane.h
- ut_kvp.h
- ut_log.h
These modules work together to enable a streamlined unit testing process, offering functionality for message handling, key-value pair (KVP) data parsing, and logging.
This module establishes a control plane that facilitates communication between different parts of the system under test. It operates on a message-based paradigm, allowing components to register callback functions that are triggered when specific messages are received.
-
Initialisation (
UT_ControlPlane_Init
): Creates a control plane instance associated with a designated port for monitoring incoming messages. -
Callback Registration (
UT_ControlPlane_RegisterCallbackOnMessage
): Associates message keys (strings) with user-defined callback functions. These callbacks are invoked when a message with the corresponding key is received. -
Life-cycle Management (
UT_ControlPlane_Start
,UT_ControlPlane_Stop
,UT_ControlPlane_Exit
): Controls the control plane's operation, allowing you to start/stop message monitoring and release resources when finished.
ut_controlPlane_instance_t *controlPlane = UT_ControlPlane_Init(8080); // Monitor port 8080
UT_ControlPlane_RegisterCallbackOnMessage(controlPlane, "command1", myCallback, NULL); // Register callback for "command1"
UT_ControlPlane_Start(controlPlane);
// ... (Control plane runs, executing callbacks as messages are received)
UT_ControlPlane_Stop(controlPlane);
UT_ControlPlane_Exit(controlPlane);
For more detailed information on ut-control_plane
see ut_control_plane: Overview (ut_control_plane.h)
This module simplifies the parsing and handling of configuration data stored in key-value pair (KVP) format. It provides functions for reading KVP data from files or memory and retrieving values by key.
-
KVP Instance Management (
ut_kvp_createInstance
,ut_kvp_destroyInstance
): Creates and destroys instances for holding KVP data. -
Data Loading (
ut_kvp_open
,ut_kvp_openMemory
): Parses KVP data from files or memory buffers into KVP instances. Multiple files can be opened and concatenated together into a single KVP instance using these functions. This allows all variables from all files to be accessible within the instance. -
Value Retrieval (
ut_kvp_getBoolField
,ut_kvp_getStringField
, etc.): Retrieves values of different data types (boolean, string, integer, float) based on their keys.
ut_kvp_instance_t *kvp = ut_kvp_createInstance();
ut_kvp_open(kvp, "config1.txt"); // Load KVP data from the first file
ut_kvp_open(kvp, "config2.txt"); // Load KVP data from the second file - concatenated with the first
bool enabled = ut_kvp_getBoolField(kvp, "featureEnabled"); // Access variables from both files
char buffer[256];
ut_kvp_getStringField(kvp, "name", buffer, sizeof(buffer));
ut_kvp_destroyInstance(kvp);
The ut_kvp
module has been enhanced internally to support including external YAML files, providing a way to modularize and reuse configuration data.
Key Features:
-
Local File Inclusion: Reference YAML files within your project's directory structure using the
!include file:xxx
directive. -
Remote File Inclusion: Fetch YAML files from URLs using the
!include https://...
directive. - Unlimited Nesting: Include as many files as needed, and those files can include other files, forming a hierarchical structure.
For more detailed information on ut_kvp.h
, refer to the documentation on ut_kvp: Support for Includes in YAML files.
This module offers logging functionality tailored for unit testing. It enables easy logging of messages to the console (with optional colors) and to a file for detailed analysis.
-
Logging Macros (
UT_LOG
,UT_LOG_STEP
,UT_LOG_INFO
, etc.): Convenient macros for logging messages with different severity levels and automatic inclusion of file/line information. -
Log File Management (
UT_log_setLogFilePath
,UT_log_getLogFilename
): Functions to set the log file path and retrieve the log file name. -
Core Logging Functions (
UT_log
,UT_logPrefix
): Underlying functions for formatted logging, including timestamps and optional prefixes.
UT_log_setLogFilePath("/path/to/logfile.txt");
UT_LOG("Starting test...");
UT_LOG_STEP("Executing step 1");
// ... test logic
UT_LOG_ERROR("Test failed!");
For more detailed information on ut_log.h
see ut-log: Overview: UT-Log