2020-06-16 06:56:48 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Unit tests for the PRM Context Buffer Library.
|
|
|
|
|
|
|
|
Copyright (c) Microsoft Corporation
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <setjmp.h>
|
|
|
|
#include <cmocka.h>
|
|
|
|
|
|
|
|
#include <Uefi.h>
|
|
|
|
|
|
|
|
#include <Guid/ZeroGuid.h>
|
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
|
|
|
#include <Library/PrintLib.h>
|
|
|
|
#include <Library/PrmContextBufferLib.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
|
|
#include <Library/UnitTestLib.h>
|
|
|
|
#include <Protocol/PrmConfig.h>
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
#define UNIT_TEST_NAME "PRM Context Buffer Library Unit Test"
|
|
|
|
#define UNIT_TEST_VERSION "0.1"
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
/// === TEST DATA ==================================================================================
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
EFI_HANDLE mTestProtocolHandle;
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
// *----------------------------------------------------------------------------------*
|
|
|
|
// * Context Structures *
|
|
|
|
// *----------------------------------------------------------------------------------*
|
2020-06-16 06:56:48 +02:00
|
|
|
typedef struct {
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *InstallationStructure;
|
|
|
|
EFI_HANDLE Handle;
|
|
|
|
PRM_GUID_SEARCH_TYPE GuidSearchType;
|
|
|
|
EFI_GUID *Guid;
|
|
|
|
EFI_GUID *ExpectedModuleGuid;
|
|
|
|
EFI_STATUS ExpectedStatus;
|
2020-06-16 06:56:48 +02:00
|
|
|
} PRM_CONTEXT_BUFFERS_TEST_CONTEXT;
|
|
|
|
|
|
|
|
typedef struct {
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_GUID *HandlerGuid;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *ContextBuffers;
|
|
|
|
PRM_CONTEXT_BUFFER *ExpectedContextBuffer;
|
|
|
|
EFI_STATUS ExpectedStatus;
|
2020-06-16 06:56:48 +02:00
|
|
|
} PRM_CONTEXT_BUFFER_TEST_CONTEXT;
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
// *----------------------------------------------------------------------------------*
|
|
|
|
// * Test GUIDs *
|
|
|
|
// *----------------------------------------------------------------------------------*
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {52960b90-2f3a-4917-b91a-ed5f599a8809}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define HANDLER_TEST_GUID_1 {0x52960b90, 0x2f3a, 0x4917, { 0xb9, 0x1a, 0xed, 0x5f, 0x59, 0x9a, 0x88, 0x09 }}
|
|
|
|
EFI_GUID mHandlerTestGuid1 = HANDLER_TEST_GUID_1;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {9316a80d-06dc-417b-b21d-6b3c2ae4ed6f}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define HANDLER_TEST_GUID_2 {0x9316a80d, 0x06dc, 0x417b, { 0xb2, 0x1d, 0x6b, 0x3c, 0x2a, 0xe4, 0xed, 0x6f }}
|
|
|
|
EFI_GUID mHandlerTestGuid2 = HANDLER_TEST_GUID_2;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {d32ac8ba-6cc6-456f-9ed9-9233fa310434}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define HANDLER_TEST_GUID_3 {0xd32ac8ba, 0x6cc6, 0x456f, { 0x9e, 0xd9, 0x92, 0x33, 0xfa, 0x31, 0x04, 0x34 }}
|
|
|
|
EFI_GUID mHandlerTestGuid3 = HANDLER_TEST_GUID_3;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {faadaa95-070b-4a34-a919-18305dc07370}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define MODULE_TEST_GUID_1 {0xfaadaa95, 0x070b, 0x4a34, { 0xa9, 0x19, 0x18, 0x30, 0x5d, 0xc0, 0x73, 0x70 }}
|
|
|
|
EFI_GUID mModuleTestGuid1 = MODULE_TEST_GUID_1;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {0ea24584-731c-4863-9100-75780af509a7}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define MODULE_TEST_GUID_2 {0x0ea24584, 0x731c, 0x4863, { 0x91, 0x00, 0x75, 0x78, 0x0a, 0xf5, 0x09, 0xa7 }}
|
|
|
|
EFI_GUID mModuleTestGuid2 = MODULE_TEST_GUID_2;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {f456b7a1-82a6-4427-8486-87e3a602df43}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define MODULE_TEST_GUID_3 {0xf456b7a1, 0x82a6, 0x4427, { 0x84, 0x86, 0x87, 0xe3, 0xa6, 0x02, 0xdf, 0x43 }}
|
|
|
|
EFI_GUID mModuleTestGuid3 = MODULE_TEST_GUID_3;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// {4a941a9c-9dcf-471b-94b5-d9e2d8c64a1b}
|
2022-03-15 19:46:34 +01:00
|
|
|
#define NEGATIVE_TEST_GUID {0x4a941a9c, 0x9dcf, 0x471b, {0x94, 0xb5, 0xd9, 0xe2, 0xd8, 0xc6, 0x4a, 0x1b }}
|
|
|
|
EFI_GUID mNegativeTestGuid = NEGATIVE_TEST_GUID;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
// *----------------------------------------------------------------------------------*
|
|
|
|
// * PRM Static Test Structures *
|
|
|
|
// *----------------------------------------------------------------------------------*
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_DATA_BUFFER mTestStaticDataBuffer1 = {
|
2020-06-16 06:56:48 +02:00
|
|
|
{
|
|
|
|
PRM_DATA_BUFFER_HEADER_SIGNATURE,
|
|
|
|
sizeof (PRM_DATA_BUFFER)
|
|
|
|
}
|
|
|
|
// No data in the buffer (only a header)
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_CONTEXT_BUFFER mTestPrmContextBuffer1 = {
|
2020-06-16 06:56:48 +02:00
|
|
|
PRM_CONTEXT_BUFFER_SIGNATURE, // Signature
|
|
|
|
PRM_CONTEXT_BUFFER_INTERFACE_VERSION, // Version
|
|
|
|
0, // Reserved
|
|
|
|
HANDLER_TEST_GUID_1, // HandlerGuid
|
|
|
|
&mTestStaticDataBuffer1 // StaticDataBuffer
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_CONTEXT_BUFFER mTestPrmContextBuffer2[2] = {
|
2020-06-16 06:56:48 +02:00
|
|
|
// Context buffer #1
|
|
|
|
{
|
|
|
|
PRM_CONTEXT_BUFFER_SIGNATURE, // Signature
|
|
|
|
PRM_CONTEXT_BUFFER_INTERFACE_VERSION, // Version
|
|
|
|
0, // Reserved
|
|
|
|
HANDLER_TEST_GUID_2, // HandlerGuid
|
|
|
|
NULL // StaticDataBuffer
|
|
|
|
},
|
|
|
|
// Context buffer #2
|
|
|
|
{
|
|
|
|
PRM_CONTEXT_BUFFER_SIGNATURE, // Signature
|
|
|
|
PRM_CONTEXT_BUFFER_INTERFACE_VERSION, // Version
|
|
|
|
0, // Reserved
|
|
|
|
HANDLER_TEST_GUID_3, // HandlerGuid
|
|
|
|
&mTestStaticDataBuffer1 // StaticDataBuffer (reuse buffer StaticDataBuffer1)
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_MODULE_CONTEXT_BUFFERS mTestPrmModuleContextBuffers1 = {
|
2020-06-16 06:56:48 +02:00
|
|
|
MODULE_TEST_GUID_1,
|
|
|
|
1,
|
|
|
|
&mTestPrmContextBuffer1,
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_MODULE_CONTEXT_BUFFERS mTestPrmModuleContextBuffers2 = {
|
2020-06-16 06:56:48 +02:00
|
|
|
MODULE_TEST_GUID_2,
|
|
|
|
1,
|
|
|
|
&mTestPrmContextBuffer1,
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_MODULE_CONTEXT_BUFFERS mTestPrmModuleContextBuffers3 = {
|
2020-06-16 06:56:48 +02:00
|
|
|
MODULE_TEST_GUID_3,
|
|
|
|
2,
|
|
|
|
&mTestPrmContextBuffer2[0],
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
// *----------------------------------------------------------------------------------*
|
|
|
|
// * Test Contexts *
|
|
|
|
// *----------------------------------------------------------------------------------*
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
// * Searches by module GUID *
|
2020-06-16 06:56:48 +02:00
|
|
|
// +--------------------------------+--------+----------------+--------------------+--------------------+--------------------+
|
|
|
|
// + InstallationStructure | Handle | GuidSearchType | Guid | ExpectedModuleGuid | ExpectedStatus |
|
|
|
|
// +--------------------------------+--------+----------------+--------------------+--------------------+--------------------+
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers00 = { &mTestPrmModuleContextBuffers1, NULL, ByModuleGuid, &mModuleTestGuid1, &mModuleTestGuid1, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers01 = { &mTestPrmModuleContextBuffers2, NULL, ByModuleGuid, &mModuleTestGuid2, &mModuleTestGuid2, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers02 = { &mTestPrmModuleContextBuffers3, NULL, ByModuleGuid, &mModuleTestGuid3, &mModuleTestGuid3, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers03 = { &mTestPrmModuleContextBuffers3, NULL, ByModuleGuid, &mNegativeTestGuid, &gZeroGuid, EFI_NOT_FOUND };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers04 = { &mTestPrmModuleContextBuffers1, NULL, ByModuleGuid, &gZeroGuid, &gZeroGuid, EFI_NOT_FOUND };
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
// * Searches by handler GUID *
|
2020-06-16 06:56:48 +02:00
|
|
|
// +--------------------------------+--------+----------------+--------------------+--------------------+--------------------+
|
|
|
|
// + InstallationStructure | Handle | GuidSearchType | Guid | ExpectedModuleGuid | ExpectedStatus |
|
|
|
|
// +--------------------------------+--------+----------------+--------------------+--------------------+--------------------+
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers05 = { &mTestPrmModuleContextBuffers1, NULL, ByHandlerGuid, &mHandlerTestGuid1, &mModuleTestGuid1, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers06 = { &mTestPrmModuleContextBuffers1, NULL, ByHandlerGuid, &gZeroGuid, &gZeroGuid, EFI_NOT_FOUND };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers07 = { &mTestPrmModuleContextBuffers2, NULL, ByHandlerGuid, &mHandlerTestGuid1, &mModuleTestGuid2, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers08 = { &mTestPrmModuleContextBuffers2, NULL, ByHandlerGuid, &mNegativeTestGuid, &gZeroGuid, EFI_NOT_FOUND };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers09 = { &mTestPrmModuleContextBuffers3, NULL, ByHandlerGuid, &mHandlerTestGuid1, &gZeroGuid, EFI_NOT_FOUND };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers10 = { &mTestPrmModuleContextBuffers3, NULL, ByHandlerGuid, &mHandlerTestGuid2, &mModuleTestGuid3, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers11 = { &mTestPrmModuleContextBuffers3, NULL, ByHandlerGuid, &mHandlerTestGuid3, &mModuleTestGuid3, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT mContextBuffers12 = { &mTestPrmModuleContextBuffers3, NULL, ByHandlerGuid, &gZeroGuid, &gZeroGuid, EFI_NOT_FOUND };
|
|
|
|
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT *mContextBuffersArray[] = {
|
2020-06-16 06:56:48 +02:00
|
|
|
&mContextBuffers00,
|
|
|
|
&mContextBuffers01,
|
|
|
|
&mContextBuffers02,
|
|
|
|
&mContextBuffers03,
|
|
|
|
&mContextBuffers04,
|
|
|
|
&mContextBuffers05,
|
|
|
|
&mContextBuffers06,
|
|
|
|
&mContextBuffers07,
|
|
|
|
&mContextBuffers08,
|
|
|
|
&mContextBuffers09,
|
|
|
|
&mContextBuffers10,
|
|
|
|
&mContextBuffers11,
|
|
|
|
&mContextBuffers12
|
|
|
|
};
|
|
|
|
|
|
|
|
// +----------------------+----------------------------------+------------------------------------------+--------------------+
|
|
|
|
// + HandlerGuid | ContextBuffers | ExpectedContextBuffer | ExpectedStatus |
|
|
|
|
// +----------------------+----------------------------------+------------------------------------------+--------------------+
|
2022-03-15 19:46:34 +01:00
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT mContextBuffer00 = { &mHandlerTestGuid1, &mTestPrmModuleContextBuffers1, &mTestPrmContextBuffer1, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT mContextBuffer01 = { &mHandlerTestGuid1, &mTestPrmModuleContextBuffers2, &mTestPrmContextBuffer1, EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT mContextBuffer02 = { &mHandlerTestGuid2, &mTestPrmModuleContextBuffers3, &mTestPrmContextBuffer2[0], EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT mContextBuffer03 = { &mHandlerTestGuid3, &mTestPrmModuleContextBuffers3, &mTestPrmContextBuffer2[1], EFI_SUCCESS };
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT mContextBuffer04 = { &mNegativeTestGuid, &mTestPrmModuleContextBuffers1, NULL, EFI_NOT_FOUND };
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT mContextBuffer05 = { &gZeroGuid, &mTestPrmModuleContextBuffers3, NULL, EFI_NOT_FOUND };
|
|
|
|
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT *mContextBufferArray[] = {
|
2020-06-16 06:56:48 +02:00
|
|
|
&mContextBuffer00,
|
|
|
|
&mContextBuffer01,
|
|
|
|
&mContextBuffer02,
|
|
|
|
&mContextBuffer03,
|
|
|
|
&mContextBuffer04,
|
|
|
|
&mContextBuffer05
|
|
|
|
};
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
/// === HELPER FUNCTIONS ===========================================================================
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
// None
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
/// === TEST CASES =================================================================================
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
/// ===== BASIC SUITE ==================================================
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Verifies that passing NULL arguments to all library functions fails with EFI_INVALID_PARAMETER.
|
|
|
|
|
|
|
|
@param[in] Context [Optional] An optional context parameter.
|
|
|
|
Not used in this unit test.
|
|
|
|
|
|
|
|
@retval UNIT_TEST_PASSED Unit test case prerequisites are met.
|
|
|
|
@retval UNIT_TEST_ERROR_PREREQUISITE_NOT_MET Test case should be skipped..
|
|
|
|
|
|
|
|
**/
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
NullPointerArgumentsShouldFailGracefully (
|
2022-03-15 19:46:34 +01:00
|
|
|
IN UNIT_TEST_CONTEXT Context
|
2020-06-16 06:56:48 +02:00
|
|
|
)
|
|
|
|
{
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_GUID Guid;
|
|
|
|
PRM_CONTEXT_BUFFER *ContextBufferPtr;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS ModuleContextBuffers;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *ModuleContextBuffersPtr;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
UT_ASSERT_EQUAL (FindContextBufferInModuleBuffers (NULL, NULL, NULL), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (FindContextBufferInModuleBuffers (NULL, &ModuleContextBuffers, &ContextBufferPtr), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (FindContextBufferInModuleBuffers (&Guid, NULL, &ContextBufferPtr), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (FindContextBufferInModuleBuffers (&Guid, &ModuleContextBuffers, NULL), EFI_INVALID_PARAMETER);
|
|
|
|
|
|
|
|
UT_ASSERT_EQUAL (GetModuleContextBuffers (ByModuleGuid, NULL, NULL), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (GetModuleContextBuffers (ByModuleGuid, NULL, &ModuleContextBuffersPtr), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (GetModuleContextBuffers (ByModuleGuid, &Guid, NULL), EFI_INVALID_PARAMETER);
|
|
|
|
|
|
|
|
UT_ASSERT_EQUAL (GetContextBuffer (NULL, NULL, NULL), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (GetContextBuffer (NULL, &ModuleContextBuffers, &ContextBufferPtr), EFI_INVALID_PARAMETER);
|
|
|
|
UT_ASSERT_EQUAL (GetContextBuffer (&Guid, NULL, &ContextBufferPtr), EFI_NOT_FOUND);
|
|
|
|
UT_ASSERT_EQUAL (GetContextBuffer (&Guid, &ModuleContextBuffers, NULL), EFI_INVALID_PARAMETER);
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
/// ===== FUNCTIONAL CORRECTNESS SUITE ==================================================
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Functional Correctness pre-requisite function.
|
|
|
|
|
|
|
|
Installs a gPrmConfigProtocolGuid protocol instance as specified by the provided
|
|
|
|
context in preparation for unit test execution
|
|
|
|
|
|
|
|
@param[in] Context [Optional] An optional parameter that enables:
|
|
|
|
A pointer to a PRM_CONTEXT_BUFFERS_TEST_CONTEXT structure with
|
|
|
|
context information for this unit test.
|
|
|
|
|
|
|
|
@retval UNIT_TEST_PASSED Unit test case prerequisites
|
|
|
|
are met.
|
|
|
|
@retval UNIT_TEST_ERROR_PREREQUISITE_NOT_MET Test case should be skipped.
|
|
|
|
|
|
|
|
**/
|
|
|
|
STATIC
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
InitializeFunctionalCorrectness (
|
2022-03-15 19:46:34 +01:00
|
|
|
IN UNIT_TEST_CONTEXT Context
|
2020-06-16 06:56:48 +02:00
|
|
|
)
|
|
|
|
{
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_STATUS Status;
|
|
|
|
PRM_CONFIG_PROTOCOL *PrmConfigProtocol;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *ModuleContextBuffers;
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT *TestContext;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
UT_ASSERT_NOT_NULL (Context);
|
2022-03-15 19:46:34 +01:00
|
|
|
TestContext = (PRM_CONTEXT_BUFFERS_TEST_CONTEXT *)Context;
|
2020-06-16 06:56:48 +02:00
|
|
|
ModuleContextBuffers = TestContext->InstallationStructure;
|
|
|
|
|
|
|
|
PrmConfigProtocol = AllocateZeroPool (sizeof (*PrmConfigProtocol));
|
|
|
|
if (PrmConfigProtocol == NULL) {
|
|
|
|
return UNIT_TEST_ERROR_PREREQUISITE_NOT_MET;
|
|
|
|
}
|
|
|
|
|
|
|
|
CopyGuid (&PrmConfigProtocol->ModuleContextBuffers.ModuleGuid, &ModuleContextBuffers->ModuleGuid);
|
|
|
|
PrmConfigProtocol->ModuleContextBuffers.BufferCount = ModuleContextBuffers->BufferCount;
|
2022-03-15 19:46:34 +01:00
|
|
|
PrmConfigProtocol->ModuleContextBuffers.Buffer = ModuleContextBuffers->Buffer;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
Status = gBS->InstallProtocolInterface (
|
2022-03-15 19:46:34 +01:00
|
|
|
&TestContext->Handle,
|
|
|
|
&gPrmConfigProtocolGuid,
|
|
|
|
EFI_NATIVE_INTERFACE,
|
|
|
|
(VOID *)PrmConfigProtocol
|
|
|
|
);
|
2020-06-16 06:56:48 +02:00
|
|
|
UT_ASSERT_NOT_EFI_ERROR (Status);
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Functional Correctness cleanup function.
|
|
|
|
|
|
|
|
Uninstalls the gPrmConfigProtocolGuid protocol instance as specified by the
|
|
|
|
provided context. This is used to clean up the mocked protocol database after
|
|
|
|
unit test execution.
|
|
|
|
|
|
|
|
@param[in] Context [Optional] An optional parameter that enables:
|
|
|
|
A pointer to a PRM_CONTEXT_BUFFERS_TEST_CONTEXT structure with
|
|
|
|
context information for this unit test.
|
|
|
|
|
|
|
|
@retval UNIT_TEST_PASSED Test case cleanup succeeded.
|
|
|
|
@retval UNIT_TEST_ERROR_CLEANUP_FAILED Test case cleanup failed.
|
|
|
|
|
|
|
|
**/
|
|
|
|
STATIC
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
DeInitializeFunctionalCorrectness (
|
2022-03-15 19:46:34 +01:00
|
|
|
IN UNIT_TEST_CONTEXT Context
|
2020-06-16 06:56:48 +02:00
|
|
|
)
|
|
|
|
{
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_STATUS Status;
|
|
|
|
PRM_CONFIG_PROTOCOL *PrmConfigProtocol;
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT *TestContext;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
UT_ASSERT_NOT_NULL (Context);
|
2022-03-15 19:46:34 +01:00
|
|
|
TestContext = (PRM_CONTEXT_BUFFERS_TEST_CONTEXT *)Context;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
Status = gBS->HandleProtocol (
|
|
|
|
TestContext->Handle,
|
|
|
|
&gPrmConfigProtocolGuid,
|
2022-03-15 19:46:34 +01:00
|
|
|
(VOID **)&PrmConfigProtocol
|
2020-06-16 06:56:48 +02:00
|
|
|
);
|
|
|
|
UT_ASSERT_NOT_EFI_ERROR (Status);
|
|
|
|
|
|
|
|
if (!EFI_ERROR (Status)) {
|
|
|
|
Status = gBS->UninstallProtocolInterface (
|
|
|
|
TestContext->Handle,
|
|
|
|
&gPrmConfigProtocolGuid,
|
|
|
|
PrmConfigProtocol
|
2022-03-15 19:46:34 +01:00
|
|
|
);
|
2020-06-16 06:56:48 +02:00
|
|
|
UT_ASSERT_NOT_EFI_ERROR (Status);
|
|
|
|
if (!EFI_ERROR (Status)) {
|
|
|
|
FreePool (PrmConfigProtocol);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Verifies that the correct PRM_MODULE_CONTEXT_BUFFERS structure instance is found
|
|
|
|
for a given PRM module or PRM handler GUID.
|
|
|
|
|
|
|
|
@param[in] Context [Optional] An optional context parameter.
|
|
|
|
A pointer to a PRM_CONTEXT_BUFFERS_TEST_CONTEXT structure with
|
|
|
|
context information for this unit test.
|
|
|
|
|
|
|
|
@retval UNIT_TEST_PASSED Unit test case prerequisites are met.
|
|
|
|
@retval UNIT_TEST_ERROR_PREREQUISITE_NOT_MET Test case should be skipped..
|
|
|
|
|
|
|
|
**/
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
VerifyGetModuleContextBuffers (
|
2022-03-15 19:46:34 +01:00
|
|
|
IN UNIT_TEST_CONTEXT Context
|
2020-06-16 06:56:48 +02:00
|
|
|
)
|
|
|
|
{
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_STATUS Status;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *ContextBuffers;
|
|
|
|
PRM_CONTEXT_BUFFERS_TEST_CONTEXT *TestContext;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
ContextBuffers = NULL;
|
2022-03-15 19:46:34 +01:00
|
|
|
TestContext = (PRM_CONTEXT_BUFFERS_TEST_CONTEXT *)Context;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
Status = GetModuleContextBuffers (TestContext->GuidSearchType, TestContext->Guid, &ContextBuffers);
|
|
|
|
UT_ASSERT_STATUS_EQUAL (Status, TestContext->ExpectedStatus);
|
|
|
|
|
|
|
|
if (!EFI_ERROR (TestContext->ExpectedStatus)) {
|
|
|
|
UT_ASSERT_TRUE (CompareGuid (TestContext->ExpectedModuleGuid, &ContextBuffers->ModuleGuid));
|
|
|
|
UT_LOG_INFO (
|
|
|
|
"%a: Searching by %a GUID ({%g}) returned ContextBuffers at 0x%x\n",
|
|
|
|
__FUNCTION__,
|
|
|
|
((TestContext->GuidSearchType == ByModuleGuid) ? "module" : "handler"),
|
|
|
|
TestContext->Guid,
|
2022-03-15 19:46:34 +01:00
|
|
|
(UINTN)ContextBuffers
|
2020-06-16 06:56:48 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Verifies that the expected PRM_CONTEXT_BUFFER instance is found for the given HandlerGuid
|
|
|
|
in the provided PRM_MODULE_CONTEXT_BUFFERS structure.
|
|
|
|
|
|
|
|
@param[in] Context [Optional] An optional context parameter.
|
|
|
|
A pointer to a PRM_CONTEXT_BUFFERS_TEST_CONTEXT structure with
|
|
|
|
context information for this unit test.
|
|
|
|
|
|
|
|
@retval UNIT_TEST_PASSED Unit test case prerequisites are met.
|
|
|
|
@retval UNIT_TEST_ERROR_PREREQUISITE_NOT_MET Test case should be skipped..
|
|
|
|
|
|
|
|
**/
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
VerifyFindContextBufferInModuleBuffers (
|
2022-03-15 19:46:34 +01:00
|
|
|
IN UNIT_TEST_CONTEXT Context
|
2020-06-16 06:56:48 +02:00
|
|
|
)
|
|
|
|
{
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_STATUS Status;
|
|
|
|
PRM_CONTEXT_BUFFER *FoundContextBuffer;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *ContextBuffers;
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT *TestContext;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
ContextBuffers = NULL;
|
2020-06-16 06:56:48 +02:00
|
|
|
FoundContextBuffer = NULL;
|
2022-03-15 19:46:34 +01:00
|
|
|
TestContext = (PRM_CONTEXT_BUFFER_TEST_CONTEXT *)Context;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
Status = FindContextBufferInModuleBuffers (TestContext->HandlerGuid, TestContext->ContextBuffers, &FoundContextBuffer);
|
|
|
|
UT_ASSERT_STATUS_EQUAL (Status, TestContext->ExpectedStatus);
|
|
|
|
|
|
|
|
if (!EFI_ERROR (TestContext->ExpectedStatus)) {
|
|
|
|
UT_ASSERT_NOT_NULL (FoundContextBuffer);
|
|
|
|
UT_ASSERT_TRUE (FoundContextBuffer == TestContext->ExpectedContextBuffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Verifies that the expected PRM_CONTEXT_BUFFER instance is found for the given HandlerGuid.
|
|
|
|
|
|
|
|
This function checks both the case when a PRM_MODULE_CONTEXT_BUFFERS structure pointer is provided and
|
|
|
|
not provided.
|
|
|
|
|
|
|
|
NOTES:
|
|
|
|
- In the future, this function should mock the internal calls to other library functions but the direct
|
|
|
|
calls are left in place for now.
|
|
|
|
- The PrmModuleContextBuffers being NULL is not actually tested at the moment. In the future, that case
|
|
|
|
should also be added.
|
|
|
|
|
|
|
|
@param[in] Context [Optional] An optional context parameter.
|
|
|
|
A pointer to a PRM_CONTEXT_BUFFERS_TEST_CONTEXT structure with
|
|
|
|
context information for this unit test.
|
|
|
|
|
|
|
|
@retval UNIT_TEST_PASSED Unit test case prerequisites are met.
|
|
|
|
@retval UNIT_TEST_ERROR_PREREQUISITE_NOT_MET Test case should be skipped..
|
|
|
|
|
|
|
|
**/
|
|
|
|
UNIT_TEST_STATUS
|
|
|
|
EFIAPI
|
|
|
|
VerifyGetContextBuffer (
|
2022-03-15 19:46:34 +01:00
|
|
|
IN UNIT_TEST_CONTEXT Context
|
2020-06-16 06:56:48 +02:00
|
|
|
)
|
|
|
|
{
|
2022-03-15 19:46:34 +01:00
|
|
|
EFI_STATUS Status;
|
|
|
|
PRM_CONTEXT_BUFFER *FoundContextBuffer;
|
|
|
|
PRM_MODULE_CONTEXT_BUFFERS *ContextBuffers;
|
|
|
|
PRM_CONTEXT_BUFFER_TEST_CONTEXT *TestContext;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
ContextBuffers = NULL;
|
2020-06-16 06:56:48 +02:00
|
|
|
FoundContextBuffer = NULL;
|
2022-03-15 19:46:34 +01:00
|
|
|
TestContext = (PRM_CONTEXT_BUFFER_TEST_CONTEXT *)Context;
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
Status = GetContextBuffer (TestContext->HandlerGuid, TestContext->ContextBuffers, &FoundContextBuffer);
|
|
|
|
UT_ASSERT_STATUS_EQUAL (Status, TestContext->ExpectedStatus);
|
|
|
|
|
|
|
|
if (!EFI_ERROR (TestContext->ExpectedStatus)) {
|
|
|
|
UT_ASSERT_NOT_NULL (FoundContextBuffer);
|
|
|
|
UT_ASSERT_TRUE (FoundContextBuffer == TestContext->ExpectedContextBuffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
return UNIT_TEST_PASSED;
|
|
|
|
}
|
|
|
|
|
2022-03-15 19:46:34 +01:00
|
|
|
/// === TEST ENGINE ================================================================================
|
2020-06-16 06:56:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Entry point for the PRM Context Buffer Library unit tests.
|
|
|
|
|
|
|
|
@param[in] ImageHandle The firmware allocated handle for the EFI image.
|
|
|
|
@param[in] SystemTable A pointer to the EFI System Table.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The entry point executed successfully.
|
|
|
|
@retval other Some error occurred when executing this entry point.
|
|
|
|
|
|
|
|
**/
|
2022-03-15 19:46:34 +01:00
|
|
|
int
|
|
|
|
main (
|
|
|
|
)
|
2020-06-16 06:56:48 +02:00
|
|
|
{
|
|
|
|
EFI_STATUS Status;
|
|
|
|
UINTN Index;
|
|
|
|
UNIT_TEST_FRAMEWORK_HANDLE Framework;
|
|
|
|
UNIT_TEST_SUITE_HANDLE BasicTests;
|
|
|
|
UNIT_TEST_SUITE_HANDLE FunctionalCorrectnessTests;
|
|
|
|
CHAR8 TestCaseClassNameString[256];
|
|
|
|
CHAR8 TestCaseDescriptionString[256];
|
|
|
|
|
|
|
|
Framework = NULL;
|
|
|
|
|
|
|
|
DEBUG ((DEBUG_INFO, "%a v%a\n", UNIT_TEST_NAME, UNIT_TEST_VERSION));
|
|
|
|
|
|
|
|
//
|
|
|
|
// Start setting up the test framework for running the tests.
|
|
|
|
//
|
|
|
|
Status = InitUnitTestFramework (&Framework, UNIT_TEST_NAME, gEfiCallerBaseName, UNIT_TEST_VERSION);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
DEBUG ((DEBUG_ERROR, "Failed in InitUnitTestFramework. Status = %r\n", Status));
|
|
|
|
goto EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Add all test suites and tests.
|
|
|
|
//
|
|
|
|
Status = CreateUnitTestSuite (&BasicTests, Framework, "Basic Context Buffer Tests", "PrmContextBufferLib.Basic", NULL, NULL);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
DEBUG ((DEBUG_ERROR, "Failed in CreateUnitTestSuite for PrmContextBufferLib.Basic\n"));
|
|
|
|
Status = EFI_OUT_OF_RESOURCES;
|
|
|
|
goto EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
AddTestCase (
|
|
|
|
BasicTests,
|
|
|
|
"",
|
|
|
|
"PrmContextBufferLib.Basic.NullPointerGracefulFailure",
|
|
|
|
NullPointerArgumentsShouldFailGracefully,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
);
|
|
|
|
|
|
|
|
Status = CreateUnitTestSuite (&FunctionalCorrectnessTests, Framework, "Functional Correctness Tests", "PrmContextBufferLib.Functional", NULL, NULL);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
DEBUG ((DEBUG_ERROR, "Failed in CreateUnitTestSuite for PrmContextBufferLib.Functional\n"));
|
|
|
|
Status = EFI_OUT_OF_RESOURCES;
|
|
|
|
goto EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Add Functional Correctness unit tests
|
|
|
|
//
|
|
|
|
for (Index = 0; Index < ARRAY_SIZE (mContextBuffersArray); Index++) {
|
|
|
|
ZeroMem (&TestCaseClassNameString[0], ARRAY_SIZE (TestCaseClassNameString));
|
|
|
|
ZeroMem (&TestCaseDescriptionString[0], ARRAY_SIZE (TestCaseDescriptionString));
|
|
|
|
|
|
|
|
AsciiSPrint (
|
|
|
|
&TestCaseClassNameString[0],
|
|
|
|
ARRAY_SIZE (TestCaseClassNameString),
|
|
|
|
"PrmContextBufferLib.Functional.VerifyGetModuleContextBuffers%d",
|
|
|
|
Index + 1
|
|
|
|
);
|
|
|
|
AsciiSPrint (
|
|
|
|
&TestCaseDescriptionString[0],
|
|
|
|
ARRAY_SIZE (TestCaseDescriptionString),
|
|
|
|
"Verify Get PRM Module Context Buffers Structure by %a GUID %d\n",
|
|
|
|
((mContextBuffersArray[Index]->GuidSearchType == ByModuleGuid) ? "module" : "handler"),
|
|
|
|
Index + 1
|
|
|
|
);
|
|
|
|
|
|
|
|
AddTestCase (
|
|
|
|
FunctionalCorrectnessTests,
|
|
|
|
&TestCaseDescriptionString[0],
|
|
|
|
&TestCaseClassNameString[0],
|
|
|
|
VerifyGetModuleContextBuffers,
|
|
|
|
InitializeFunctionalCorrectness,
|
|
|
|
DeInitializeFunctionalCorrectness,
|
|
|
|
mContextBuffersArray[Index]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (Index = 0; Index < ARRAY_SIZE (mContextBufferArray); Index++) {
|
|
|
|
ZeroMem (&TestCaseClassNameString[0], ARRAY_SIZE (TestCaseClassNameString));
|
|
|
|
ZeroMem (&TestCaseDescriptionString[0], ARRAY_SIZE (TestCaseDescriptionString));
|
|
|
|
|
|
|
|
AsciiSPrint (
|
|
|
|
&TestCaseClassNameString[0],
|
|
|
|
ARRAY_SIZE (TestCaseClassNameString),
|
|
|
|
"PrmContextBufferLib.Functional.VerifyFindContextBufferInModuleBuffers%d",
|
|
|
|
Index + 1
|
|
|
|
);
|
|
|
|
AsciiSPrint (
|
|
|
|
&TestCaseDescriptionString[0],
|
|
|
|
ARRAY_SIZE (TestCaseDescriptionString),
|
|
|
|
"Verify Find PRM Context Buffer by Handler GUID %d\n",
|
|
|
|
Index + 1
|
|
|
|
);
|
|
|
|
|
|
|
|
AddTestCase (
|
|
|
|
FunctionalCorrectnessTests,
|
|
|
|
&TestCaseDescriptionString[0],
|
|
|
|
&TestCaseClassNameString[0],
|
|
|
|
VerifyFindContextBufferInModuleBuffers,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
mContextBufferArray[Index]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (Index = 0; Index < ARRAY_SIZE (mContextBufferArray); Index++) {
|
|
|
|
ZeroMem (&TestCaseClassNameString[0], ARRAY_SIZE (TestCaseClassNameString));
|
|
|
|
ZeroMem (&TestCaseDescriptionString[0], ARRAY_SIZE (TestCaseDescriptionString));
|
|
|
|
|
|
|
|
AsciiSPrint (
|
|
|
|
&TestCaseClassNameString[0],
|
|
|
|
ARRAY_SIZE (TestCaseClassNameString),
|
|
|
|
"PrmContextBufferLib.Functional.VerifyGetContextBuffer%d",
|
|
|
|
Index + 1
|
|
|
|
);
|
|
|
|
AsciiSPrint (
|
|
|
|
&TestCaseDescriptionString[0],
|
|
|
|
ARRAY_SIZE (TestCaseDescriptionString),
|
|
|
|
"Verify Get PRM Context Buffer by Handler GUID %d\n",
|
|
|
|
Index + 1
|
|
|
|
);
|
|
|
|
|
|
|
|
AddTestCase (
|
|
|
|
FunctionalCorrectnessTests,
|
|
|
|
&TestCaseDescriptionString[0],
|
|
|
|
&TestCaseClassNameString[0],
|
|
|
|
VerifyGetContextBuffer,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
mContextBufferArray[Index]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Execute the tests.
|
|
|
|
//
|
|
|
|
Status = RunAllTestSuites (Framework);
|
|
|
|
|
|
|
|
EXIT:
|
2022-03-15 19:46:34 +01:00
|
|
|
if (Framework) {
|
2020-06-16 06:56:48 +02:00
|
|
|
FreeUnitTestFramework (Framework);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Status;
|
|
|
|
}
|