UnitTestFrameworkPkg: Add gmock support to GoogleTestLib
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4389 * Add gmock support to GoogleTestLib * Add FunctionMockLib library class and library instance * Add GoogleTest extension to GoogleTestLib.h for CHAR16 type * Add GoogleTest extension to GoogleTestLib.h for buffer types * HOST_APPLICATION only supports IA32/X64 Cc: Sean Brogan <sean.brogan@microsoft.com> Cc: Michael Kubacki <mikuback@linux.microsoft.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Chris Johnson <chris.n.johnson@intel.com> Reviewed-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Oliver Smith-Denny <osde@linux.microsoft.com> Reviewed-by: Michael D Kinney <michael.d.kinney@intel.com>
This commit is contained in:
committed by
mergify[bot]
parent
caa389625f
commit
d0252b8fc1
@ -10,5 +10,101 @@
|
||||
#define GOOGLE_TEST_LIB_H_
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
#include <gmock/gmock.h>
|
||||
#include <cstring>
|
||||
|
||||
extern "C" {
|
||||
#include <Uefi.h>
|
||||
}
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
// Below are the action extensions to GoogleTest and gmock for EDK2 types.
|
||||
// These actions are intended to be used in EXPECT_CALL (and related gmock
|
||||
// macros) to support assignments to output arguments in the expected call.
|
||||
//
|
||||
|
||||
// Action to support pointer types to a buffer (such as UINT8* or VOID*)
|
||||
ACTION_TEMPLATE (
|
||||
SetArgBuffer,
|
||||
HAS_1_TEMPLATE_PARAMS (size_t, ArgNum),
|
||||
AND_2_VALUE_PARAMS (Buffer, ByteSize)
|
||||
) {
|
||||
auto ArgBuffer = std::get<ArgNum>(args);
|
||||
|
||||
std::memcpy (ArgBuffer, Buffer, ByteSize);
|
||||
}
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////
|
||||
// Below are the matcher extensions to GoogleTest and gmock for EDK2 types.
|
||||
// These matchers are intended to be used in EXPECT_CALL (and related gmock
|
||||
// macros) to support comparisons to input arguments in the expected call.
|
||||
//
|
||||
// Note that these matchers can also be used in the EXPECT_THAT or ASSERT_THAT
|
||||
// macros to compare whether two values are equal.
|
||||
//
|
||||
|
||||
// Matcher to support pointer types to a buffer (such as UINT8* or VOID* or
|
||||
// any structure pointer)
|
||||
MATCHER_P2 (
|
||||
BufferEq,
|
||||
Buffer,
|
||||
ByteSize,
|
||||
std::string ("buffer data to ") + (negation ? "not " : "") + "be the same"
|
||||
) {
|
||||
UINT8 *Actual = (UINT8 *)arg;
|
||||
UINT8 *Expected = (UINT8 *)Buffer;
|
||||
|
||||
for (size_t i = 0; i < ByteSize; i++) {
|
||||
if (Actual[i] != Expected[i]) {
|
||||
*result_listener << "byte at offset " << i
|
||||
<< " does not match expected. [" << std::hex
|
||||
<< "Actual: 0x" << std::setw (2) << std::setfill ('0')
|
||||
<< (unsigned int)Actual[i] << ", "
|
||||
<< "Expected: 0x" << std::setw (2) << std::setfill ('0')
|
||||
<< (unsigned int)Expected[i] << "]";
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
*result_listener << "all bytes match";
|
||||
return true;
|
||||
}
|
||||
|
||||
// Matcher to support CHAR16* type
|
||||
MATCHER_P (
|
||||
Char16StrEq,
|
||||
String,
|
||||
std::string ("strings to ") + (negation ? "not " : "") + "be the same"
|
||||
) {
|
||||
CHAR16 *Actual = (CHAR16 *)arg;
|
||||
CHAR16 *Expected = (CHAR16 *)String;
|
||||
|
||||
for (size_t i = 0; Actual[i] != 0; i++) {
|
||||
if (Actual[i] != Expected[i]) {
|
||||
*result_listener << "character at offset " << i
|
||||
<< " does not match expected. [" << std::hex
|
||||
<< "Actual: 0x" << std::setw (4) << std::setfill ('0')
|
||||
<< Actual[i];
|
||||
|
||||
if (std::isprint (Actual[i])) {
|
||||
*result_listener << " ('" << (char)Actual[i] << "')";
|
||||
}
|
||||
|
||||
*result_listener << ", Expected: 0x" << std::setw (4) << std::setfill ('0')
|
||||
<< Expected[i];
|
||||
|
||||
if (std::isprint (Expected[i])) {
|
||||
*result_listener << " ('" << (char)Expected[i] << "')";
|
||||
}
|
||||
|
||||
*result_listener << "]";
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
*result_listener << "strings match";
|
||||
return true;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
Reference in New Issue
Block a user