![]() |
micro-test-plus 3.2.2
µTest++ Testing Framework
|
Functions used to compose logical expressions in tests. More...
Functions | |
template<class Lhs_T, class Rhs_T> | |
constexpr auto | micro_os_plus::micro_test_plus::_and (const Lhs_T &lhs, const Rhs_T &rhs) |
Generic logical and operation. | |
template<class Expr_T> | |
constexpr auto | micro_os_plus::micro_test_plus::_not (const Expr_T &expr) |
Generic logical not operation. | |
template<class Lhs_T, class Rhs_T> | |
constexpr auto | micro_os_plus::micro_test_plus::_or (const Lhs_T &lhs, const Rhs_T &rhs) |
Generic logical or operation. |
The µTest++ framework provides logical functions for composing complex test expressions within a single statement. The functions mt::_and(), mt::_or(), and mt::_not() enable the combination of multiple conditions, allowing for expressive and concise test logic.
These function names are prefixed with an underscore because and, or, and not are reserved keywords in both C and C++. By using these logical functions, developers can clearly express compound conditions and improve the readability of their test cases.
When the operands are function comparators, it is recommended to use the overloaded logical operators &&, ||, and ! provided within the micro_test_plus::operators namespace for even more natural expression of logical conditions.
|
nodiscardconstexpr |
Lhs_T | Type of the left hand side operand. |
Rhs_T | Type of the right hand side operand. |
[in] | lhs | Left hand side operand. |
[in] | rhs | Right hand side operand. |
The _and function template provides a generic logical conjunction for any expression types. It constructs a logical conjunction object that can be used within the µTest++ framework to assert that both given conditions are true. This function is typically used in test expectations and assertions to combine logical expressions or custom comparators.
The underscore in the function name is intentional to differentiate it from the standard logical and operator.
Definition at line 288 of file function-comparators-inlines.h.
|
nodiscardconstexpr |
Expr_T | Type of the operand. |
[in] | expr | Logical expression to be negated. |
The _not function template provides a generic logical negation for any expression type. It constructs a logical negator object that can be used within the µTest++ framework to assert that a given condition is false. This function is typically used in test expectations and assertions to invert logical expressions or custom comparators.
The underscore in the function name is intentional to differentiate it from the standard logical not operator.
Definition at line 270 of file function-comparators-inlines.h.
|
nodiscardconstexpr |
Lhs_T | Type of the left hand side operand. |
Rhs_T | Type of the right hand side operand. |
[in] | lhs | Left hand side operand. |
[in] | rhs | Right hand side operand. |
The _or function template provides a generic logical disjunction for any expression types. It constructs a logical disjunction object that can be used within the µTest++ framework to assert that at least one of the given conditions is true. This function is typically used in test expectations and assertions to combine logical expressions or custom comparators.
The underscore in the function name is intentional to differentiate it from the standard logical or operator.
Definition at line 306 of file function-comparators-inlines.h.