audk/SecurityPkg/Library/SecureBootVariableLib/UnitTest/SecureBootVariableLibUnitTe...

2038 lines
94 KiB
C
Raw Normal View History

/** @file
Unit tests of the implementation of SecureBootVariableLib.
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 <UefiSecureBoot.h>
#include <Guid/GlobalVariable.h>
#include <Guid/AuthenticatedVariableFormat.h>
#include <Guid/ImageAuthentication.h>
#include <Library/BaseLib.h>
#include <Library/BaseMemoryLib.h>
#include <Library/DebugLib.h>
#include <Library/MemoryAllocationLib.h>
#include <Library/UnitTestLib.h>
#include <Library/SecureBootVariableLib.h>
#define UNIT_TEST_APP_NAME "SecureBootVariableLib Unit Tests"
#define UNIT_TEST_APP_VERSION "1.0"
#define VAR_AUTH_DESC_SIZE OFFSET_OF (EFI_VARIABLE_AUTHENTICATION_2, AuthInfo) + OFFSET_OF (WIN_CERTIFICATE_UEFI_GUID, CertData)
extern EFI_TIME mMaxTimestamp;
extern EFI_TIME mDefaultPayloadTimestamp;
/**
Sets the value of a variable.
@param[in] VariableName A Null-terminated string that is the name of the vendor's variable.
Each VariableName is unique for each VendorGuid. VariableName must
contain 1 or more characters. If VariableName is an empty string,
then EFI_INVALID_PARAMETER is returned.
@param[in] VendorGuid A unique identifier for the vendor.
@param[in] Attributes Attributes bitmask to set for the variable.
@param[in] DataSize The size in bytes of the Data buffer. Unless the EFI_VARIABLE_APPEND_WRITE or
EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS attribute is set, a size of zero
causes the variable to be deleted. When the EFI_VARIABLE_APPEND_WRITE attribute is
set, then a SetVariable() call with a DataSize of zero will not cause any change to
the variable value (the timestamp associated with the variable may be updated however
even if no new data value is provided,see the description of the
EFI_VARIABLE_AUTHENTICATION_2 descriptor below. In this case the DataSize will not
be zero since the EFI_VARIABLE_AUTHENTICATION_2 descriptor will be populated).
@param[in] Data The contents for the variable.
@retval EFI_SUCCESS The firmware has successfully stored the variable and its data as
defined by the Attributes.
@retval EFI_INVALID_PARAMETER An invalid combination of attribute bits, name, and GUID was supplied, or the
DataSize exceeds the maximum allowed.
@retval EFI_INVALID_PARAMETER VariableName is an empty string.
@retval EFI_OUT_OF_RESOURCES Not enough storage is available to hold the variable and its data.
@retval EFI_DEVICE_ERROR The variable could not be retrieved due to a hardware error.
@retval EFI_WRITE_PROTECTED The variable in question is read-only.
@retval EFI_WRITE_PROTECTED The variable in question cannot be deleted.
@retval EFI_SECURITY_VIOLATION The variable could not be written due to EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACESS being set,
but the AuthInfo does NOT pass the validation check carried out by the firmware.
@retval EFI_NOT_FOUND The variable trying to be updated or deleted was not found.
**/
STATIC
EFI_STATUS
EFIAPI
MockSetVariable (
IN CHAR16 *VariableName,
IN EFI_GUID *VendorGuid,
IN UINT32 Attributes,
IN UINTN DataSize,
IN VOID *Data
)
{
DEBUG ((
DEBUG_INFO,
"%a %s %g %x %x %p\n",
__FUNCTION__,
VariableName,
VendorGuid,
Attributes,
DataSize,
Data
));
check_expected_ptr (VariableName);
check_expected_ptr (VendorGuid);
check_expected_ptr (Attributes);
check_expected (DataSize);
check_expected (Data);
return (EFI_STATUS)mock ();
}
/**
Returns the value of a variable.
@param[in] VariableName A Null-terminated string that is the name of the vendor's
variable.
@param[in] VendorGuid A unique identifier for the vendor.
@param[out] Attributes If not NULL, a pointer to the memory location to return the
attributes bitmask for the variable.
@param[in, out] DataSize On input, the size in bytes of the return Data buffer.
On output the size of data returned in Data.
@param[out] Data The buffer to return the contents of the variable. May be NULL
with a zero DataSize in order to determine the size buffer needed.
@retval EFI_SUCCESS The function completed successfully.
@retval EFI_NOT_FOUND The variable was not found.
@retval EFI_BUFFER_TOO_SMALL The DataSize is too small for the result.
@retval EFI_INVALID_PARAMETER VariableName is NULL.
@retval EFI_INVALID_PARAMETER VendorGuid is NULL.
@retval EFI_INVALID_PARAMETER DataSize is NULL.
@retval EFI_INVALID_PARAMETER The DataSize is not too small and Data is NULL.
@retval EFI_DEVICE_ERROR The variable could not be retrieved due to a hardware error.
@retval EFI_SECURITY_VIOLATION The variable could not be retrieved due to an authentication failure.
**/
STATIC
EFI_STATUS
EFIAPI
MockGetVariable (
IN CHAR16 *VariableName,
IN EFI_GUID *VendorGuid,
OUT UINT32 *Attributes OPTIONAL,
IN OUT UINTN *DataSize,
OUT VOID *Data OPTIONAL
)
{
UINTN TargetSize;
BOOLEAN Exist;
DEBUG ((
DEBUG_INFO,
"%a %s %g %p %x %p\n",
__FUNCTION__,
VariableName,
VendorGuid,
Attributes,
*DataSize,
Data
));
assert_non_null (DataSize);
check_expected_ptr (VariableName);
check_expected_ptr (VendorGuid);
check_expected (*DataSize);
Exist = (BOOLEAN)mock ();
if (!Exist) {
return EFI_NOT_FOUND;
}
TargetSize = (UINTN)mock ();
if (TargetSize > *DataSize) {
*DataSize = TargetSize;
return EFI_BUFFER_TOO_SMALL;
} else {
assert_non_null (Data);
CopyMem (Data, (VOID *)mock (), TargetSize);
}
return EFI_SUCCESS;
}
///
/// Mock version of the UEFI Runtime Services Table
///
EFI_RUNTIME_SERVICES gMockRuntime = {
{
EFI_RUNTIME_SERVICES_SIGNATURE, // Signature
EFI_RUNTIME_SERVICES_REVISION, // Revision
sizeof (EFI_RUNTIME_SERVICES), // HeaderSize
0, // CRC32
0 // Reserved
},
NULL, // GetTime
NULL, // SetTime
NULL, // GetWakeupTime
NULL, // SetWakeupTime
NULL, // SetVirtualAddressMap
NULL, // ConvertPointer
MockGetVariable, // GetVariable
NULL, // GetNextVariableName
MockSetVariable, // SetVariable
NULL, // GetNextHighMonotonicCount
NULL, // ResetSystem
NULL, // UpdateCapsule
NULL, // QueryCapsuleCapabilities
NULL // QueryVariableInfo
};
/**
Unit test for SetSecureBootMode () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootModeShouldSetVar (
IN UNIT_TEST_CONTEXT Context
)
{
UINT8 SecureBootMode;
EFI_STATUS Status;
SecureBootMode = 0xAB; // Any random magic number...
expect_memory (MockSetVariable, VariableName, EFI_CUSTOM_MODE_NAME, sizeof (EFI_CUSTOM_MODE_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiCustomModeEnableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS);
expect_value (MockSetVariable, DataSize, sizeof (SecureBootMode));
expect_memory (MockSetVariable, Data, &SecureBootMode, sizeof (SecureBootMode));
will_return (MockSetVariable, EFI_SUCCESS);
Status = SetSecureBootMode (SecureBootMode);
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for GetSetupMode () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
GetSetupModeShouldGetVar (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 TargetMode;
UINT8 SetupMode;
TargetMode = 0xAB; // Any random magic number...
expect_memory (MockGetVariable, VariableName, EFI_SETUP_MODE_NAME, sizeof (EFI_SETUP_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (SetupMode));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (SetupMode));
will_return (MockGetVariable, &TargetMode);
Status = GetSetupMode (&SetupMode);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (SetupMode, TargetMode);
return UNIT_TEST_PASSED;
}
/**
Unit test for GetSetupMode () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
IsSecureBootEnableShouldGetVar (
IN UNIT_TEST_CONTEXT Context
)
{
BOOLEAN Enabled;
UINT8 TargetMode;
TargetMode = SECURE_BOOT_MODE_ENABLE;
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (TargetMode));
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (TargetMode));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (TargetMode));
will_return (MockGetVariable, &TargetMode);
Enabled = IsSecureBootEnabled ();
UT_ASSERT_EQUAL (Enabled, SECURE_BOOT_MODE_ENABLE);
return UNIT_TEST_PASSED;
}
/**
Unit test for SecureBootCreateDataFromInput () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SecureBootCreateDataFromInputSimple (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_SIGNATURE_LIST *SigList = NULL;
EFI_SIGNATURE_DATA *SigData = NULL;
UINTN SigListSize = 0;
EFI_STATUS Status;
UINT8 TestData[] = { 0 };
SECURE_BOOT_CERTIFICATE_INFO KeyInfo = {
.Data = TestData,
.DataSize = sizeof (TestData)
};
Status = SecureBootCreateDataFromInput (&SigListSize, &SigList, 1, &KeyInfo);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_NOT_NULL (SigList);
UT_ASSERT_TRUE (CompareGuid (&SigList->SignatureType, &gEfiCertX509Guid));
UT_ASSERT_EQUAL (SigList->SignatureSize, sizeof (EFI_SIGNATURE_DATA) - 1 + sizeof (TestData));
UT_ASSERT_EQUAL (SigList->SignatureHeaderSize, 0);
UT_ASSERT_EQUAL (SigList->SignatureListSize, sizeof (EFI_SIGNATURE_LIST) + sizeof (EFI_SIGNATURE_DATA) - 1 + sizeof (TestData));
UT_ASSERT_EQUAL (SigList->SignatureListSize, SigListSize);
SigData = (EFI_SIGNATURE_DATA *)((UINTN)SigList + sizeof (EFI_SIGNATURE_LIST));
UT_ASSERT_TRUE (CompareGuid (&SigData->SignatureOwner, &gEfiGlobalVariableGuid));
UT_ASSERT_MEM_EQUAL (SigData->SignatureData, TestData, sizeof (TestData));
return UNIT_TEST_PASSED;
}
/**
Unit test for SecureBootCreateDataFromInput () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SecureBootCreateDataFromInputNull (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_SIGNATURE_LIST *SigList = NULL;
UINTN SigListSize = 0;
EFI_STATUS Status;
SECURE_BOOT_CERTIFICATE_INFO KeyInfo = {
.Data = NULL,
.DataSize = 0
};
Status = SecureBootCreateDataFromInput (&SigListSize, &SigList, 0, NULL);
UT_ASSERT_STATUS_EQUAL (Status, EFI_INVALID_PARAMETER);
Status = SecureBootCreateDataFromInput (&SigListSize, &SigList, 1, &KeyInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_NOT_FOUND);
return UNIT_TEST_PASSED;
}
/**
Unit test for SecureBootCreateDataFromInput () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SecureBootCreateDataFromInputMultiple (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_SIGNATURE_LIST *SigList = NULL;
EFI_SIGNATURE_DATA *SigData = NULL;
UINTN SigListSize = 0;
UINTN TotalSize = 0;
UINTN Index = 0;
UINT8 TestData1[] = { 0 };
UINT8 TestData2[] = { 1, 2 };
EFI_STATUS Status;
SECURE_BOOT_CERTIFICATE_INFO KeyInfo[2] = {
{
.Data = TestData1,
.DataSize = sizeof (TestData1)
},
{
.Data = TestData2,
.DataSize = sizeof (TestData2)
}
};
Status = SecureBootCreateDataFromInput (&SigListSize, &SigList, 2, KeyInfo);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_NOT_NULL (SigList);
for (Index = 0; Index < 2; Index++) {
UT_ASSERT_TRUE (SigListSize > TotalSize);
UT_ASSERT_TRUE (CompareGuid (&SigList->SignatureType, &gEfiCertX509Guid));
UT_ASSERT_EQUAL (SigList->SignatureSize, sizeof (EFI_SIGNATURE_DATA) - 1 + KeyInfo[Index].DataSize);
UT_ASSERT_EQUAL (SigList->SignatureHeaderSize, 0);
UT_ASSERT_EQUAL (SigList->SignatureListSize, sizeof (EFI_SIGNATURE_LIST) + sizeof (EFI_SIGNATURE_DATA) - 1 + KeyInfo[Index].DataSize);
SigData = (EFI_SIGNATURE_DATA *)((UINTN)SigList + sizeof (EFI_SIGNATURE_LIST));
UT_ASSERT_TRUE (CompareGuid (&SigData->SignatureOwner, &gEfiGlobalVariableGuid));
UT_ASSERT_MEM_EQUAL (SigData->SignatureData, KeyInfo[Index].Data, KeyInfo[Index].DataSize);
TotalSize = TotalSize + SigList->SignatureListSize;
SigList = (EFI_SIGNATURE_LIST *)((UINTN)SigList + SigList->SignatureListSize);
}
UT_ASSERT_EQUAL (SigListSize, TotalSize);
return UNIT_TEST_PASSED;
}
/**
Unit test for CreateTimeBasedPayload () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
CreateTimeBasedPayloadShouldPopulateDescriptor (
IN UNIT_TEST_CONTEXT Context
)
{
UINT8 Data[] = { 2 };
UINTN DataSize = sizeof (Data);
UINT8 *CheckData;
EFI_VARIABLE_AUTHENTICATION_2 *VarAuth;
EFI_STATUS Status;
EFI_TIME Time = {
.Year = 2012,
.Month = 3,
.Day = 4,
.Hour = 5,
.Minute = 6,
.Second = 7,
.Pad1 = 0,
.Nanosecond = 8910,
.TimeZone = 1112,
.Pad2 = 0
};
CheckData = AllocateCopyPool (DataSize, Data);
Status = CreateTimeBasedPayload (&DataSize, &CheckData, &Time);
UT_ASSERT_NOT_EFI_ERROR (Status);
// This is result that we did not pack this structure...
// we cannot even use the sizeof (EFI_VARIABLE_AUTHENTICATION_2) - 1,
// because the structure is not at the end of this structure, but partially
// inside it...
UT_ASSERT_EQUAL (DataSize, VAR_AUTH_DESC_SIZE + sizeof (Data));
UT_ASSERT_NOT_NULL (CheckData);
VarAuth = (EFI_VARIABLE_AUTHENTICATION_2 *)CheckData;
UT_ASSERT_MEM_EQUAL (&(VarAuth->TimeStamp), &Time, sizeof (EFI_TIME));
UT_ASSERT_EQUAL (VarAuth->AuthInfo.Hdr.dwLength, OFFSET_OF (WIN_CERTIFICATE_UEFI_GUID, CertData));
UT_ASSERT_EQUAL (VarAuth->AuthInfo.Hdr.wRevision, 0x0200);
UT_ASSERT_EQUAL (VarAuth->AuthInfo.Hdr.wCertificateType, WIN_CERT_TYPE_EFI_GUID);
UT_ASSERT_TRUE (CompareGuid (&VarAuth->AuthInfo.CertType, &gEfiCertPkcs7Guid));
UT_ASSERT_MEM_EQUAL (VarAuth->AuthInfo.CertData, Data, sizeof (Data));
return UNIT_TEST_PASSED;
}
/**
Unit test for CreateTimeBasedPayload () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
CreateTimeBasedPayloadShouldCheckInput (
IN UNIT_TEST_CONTEXT Context
)
{
UINTN DataSize = 0;
UINT8 *Data = NULL;
EFI_TIME Time;
EFI_STATUS Status;
Status = CreateTimeBasedPayload (NULL, &Data, &Time);
UT_ASSERT_STATUS_EQUAL (Status, EFI_INVALID_PARAMETER);
Status = CreateTimeBasedPayload (&DataSize, NULL, &Time);
UT_ASSERT_STATUS_EQUAL (Status, EFI_INVALID_PARAMETER);
Status = CreateTimeBasedPayload (&DataSize, &Data, NULL);
UT_ASSERT_STATUS_EQUAL (Status, EFI_INVALID_PARAMETER);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteDb () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteDbShouldDelete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = 0;
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mMaxTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
Status = DeleteDb ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteDbx () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteDbxShouldDelete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = 0;
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mMaxTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
Status = DeleteDbx ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteDbt () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteDbtShouldDelete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = 0;
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mMaxTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
Status = DeleteDbt ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteKEK () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteKEKShouldDelete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = 0;
expect_memory (MockGetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mMaxTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
Status = DeleteKEK ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeletePlatformKey () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeletePKShouldDelete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = 0;
UINT8 BootMode = CUSTOM_SECURE_BOOT_MODE;
expect_memory (MockSetVariable, VariableName, EFI_CUSTOM_MODE_NAME, sizeof (EFI_CUSTOM_MODE_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiCustomModeEnableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS);
expect_value (MockSetVariable, DataSize, sizeof (BootMode));
expect_memory (MockSetVariable, Data, &BootMode, sizeof (BootMode));
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mMaxTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
Status = DeletePlatformKey ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteSecureBootVariablesShouldDelete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = 0;
UINT8 BootMode = CUSTOM_SECURE_BOOT_MODE;
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mMaxTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE);
will_return (DisablePKProtection, EFI_SUCCESS);
expect_memory (MockSetVariable, VariableName, EFI_CUSTOM_MODE_NAME, sizeof (EFI_CUSTOM_MODE_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiCustomModeEnableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS);
expect_value (MockSetVariable, DataSize, sizeof (BootMode));
expect_memory (MockSetVariable, Data, &BootMode, sizeof (BootMode));
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
expect_memory (MockSetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
expect_memory (MockSetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, sizeof (Dummy));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (Dummy));
will_return (MockGetVariable, &Dummy);
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE);
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE);
will_return (MockSetVariable, EFI_SUCCESS);
Status = DeleteSecureBootVariables ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteSecureBootVariablesShouldCheckProtection (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
will_return (DisablePKProtection, EFI_SECURITY_VIOLATION);
Status = DeleteSecureBootVariables ();
UT_ASSERT_STATUS_EQUAL (Status, EFI_ABORTED);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
DeleteSecureBootVariablesShouldProceedWithNotFound (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 BootMode = CUSTOM_SECURE_BOOT_MODE;
will_return (DisablePKProtection, EFI_SUCCESS);
expect_memory (MockSetVariable, VariableName, EFI_CUSTOM_MODE_NAME, sizeof (EFI_CUSTOM_MODE_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiCustomModeEnableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS);
expect_value (MockSetVariable, DataSize, sizeof (BootMode));
expect_memory (MockSetVariable, Data, &BootMode, sizeof (BootMode));
will_return (MockSetVariable, EFI_SUCCESS);
expect_memory (MockGetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
expect_memory (MockGetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
expect_memory (MockGetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockGetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Status = DeleteSecureBootVariables ();
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for DeleteSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
EnrollFromInputShouldComplete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 Dummy = 3;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (Dummy);
Payload = AllocateCopyPool (sizeof (Dummy), &Dummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (Dummy));
expect_memory (MockSetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (Dummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (Dummy));
will_return (MockSetVariable, EFI_SUCCESS);
Status = EnrollFromInput (EFI_PLATFORM_KEY_NAME, &gEfiGlobalVariableGuid, sizeof (Dummy), &Dummy);
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldComplete (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbDummy = 0xDE;
UINT8 DbtDummy = 0xAD;
UINT8 DbxDummy = 0xBE;
UINT8 KekDummy = 0xEF;
UINT8 PkDummy = 0xFE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbPtr = &DbDummy,
.DbSize = sizeof (DbDummy),
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.DbtPtr = &DbtDummy,
.DbtSize = sizeof (DbtDummy),
.KekPtr = &KekDummy,
.KekSize = sizeof (KekDummy),
.PkPtr = &PkDummy,
.PkSize = sizeof (PkDummy),
.SecureBootKeyName = L"Food"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbDummy, sizeof (DbDummy));
PayloadSize = sizeof (DbDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbtDummy, sizeof (DbtDummy));
PayloadSize = sizeof (DbtDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &KekDummy, sizeof (KekDummy));
PayloadSize = sizeof (KekDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &PkDummy, sizeof (PkDummy));
PayloadSize = sizeof (PkDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
expect_memory (MockSetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
will_return (MockSetVariable, EFI_SUCCESS);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldStopWhenSecure (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 TargetMode = SECURE_BOOT_MODE_ENABLE;
SECURE_BOOT_PAYLOAD_INFO PayloadInfo;
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (TargetMode));
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, sizeof (TargetMode));
will_return (MockGetVariable, TRUE);
will_return (MockGetVariable, sizeof (TargetMode));
will_return (MockGetVariable, &TargetMode);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_ABORTED);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldStopFailDBX (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbxDummy = 0xBE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbxDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.SecureBootKeyName = L"Fail DBX"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_WRITE_PROTECTED);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_WRITE_PROTECTED);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldStopFailDB (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbDummy = 0xDE;
UINT8 DbxDummy = 0xBE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbPtr = &DbDummy,
.DbSize = sizeof (DbDummy),
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.SecureBootKeyName = L"Fail DB"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbDummy, sizeof (DbDummy));
PayloadSize = sizeof (DbDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
will_return (MockSetVariable, EFI_WRITE_PROTECTED);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_WRITE_PROTECTED);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldStopFailDBT (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbDummy = 0xDE;
UINT8 DbtDummy = 0xAD;
UINT8 DbxDummy = 0xBE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbPtr = &DbDummy,
.DbSize = sizeof (DbDummy),
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.DbtPtr = &DbtDummy,
.DbtSize = sizeof (DbtDummy),
.SecureBootKeyName = L"Fail DBT"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbDummy, sizeof (DbDummy));
PayloadSize = sizeof (DbDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbtDummy, sizeof (DbtDummy));
PayloadSize = sizeof (DbtDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
will_return (MockSetVariable, EFI_ACCESS_DENIED);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_ACCESS_DENIED);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldStopFailKEK (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbDummy = 0xDE;
UINT8 DbtDummy = 0xAD;
UINT8 DbxDummy = 0xBE;
UINT8 KekDummy = 0xEF;
UINT8 PkDummy = 0xFE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbPtr = &DbDummy,
.DbSize = sizeof (DbDummy),
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.DbtPtr = &DbtDummy,
.DbtSize = sizeof (DbtDummy),
.KekPtr = &KekDummy,
.KekSize = sizeof (KekDummy),
.PkPtr = &PkDummy,
.PkSize = sizeof (PkDummy),
.SecureBootKeyName = L"Food"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbDummy, sizeof (DbDummy));
PayloadSize = sizeof (DbDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbtDummy, sizeof (DbtDummy));
PayloadSize = sizeof (DbtDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &KekDummy, sizeof (KekDummy));
PayloadSize = sizeof (KekDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
will_return (MockSetVariable, EFI_DEVICE_ERROR);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_DEVICE_ERROR);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesShouldStopFailPK (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbDummy = 0xDE;
UINT8 DbtDummy = 0xAD;
UINT8 DbxDummy = 0xBE;
UINT8 KekDummy = 0xEF;
UINT8 PkDummy = 0xFE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbPtr = &DbDummy,
.DbSize = sizeof (DbDummy),
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.DbtPtr = &DbtDummy,
.DbtSize = sizeof (DbtDummy),
.KekPtr = &KekDummy,
.KekSize = sizeof (KekDummy),
.PkPtr = &PkDummy,
.PkSize = sizeof (PkDummy),
.SecureBootKeyName = L"Food"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbDummy, sizeof (DbDummy));
PayloadSize = sizeof (DbDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbtDummy, sizeof (DbtDummy));
PayloadSize = sizeof (DbtDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE2, sizeof (EFI_IMAGE_SECURITY_DATABASE2));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbtDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &KekDummy, sizeof (KekDummy));
PayloadSize = sizeof (KekDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &PkDummy, sizeof (PkDummy));
PayloadSize = sizeof (PkDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
expect_memory (MockSetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
will_return (MockSetVariable, EFI_INVALID_PARAMETER);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_STATUS_EQUAL (Status, EFI_SECURITY_VIOLATION);
return UNIT_TEST_PASSED;
}
/**
Unit test for SetDefaultSecureBootVariables () API of the SecureBootVariableLib.
@param[in] Context [Optional] An optional parameter that enables:
1) test-case reuse with varied parameters and
2) test-case re-entry for Target tests that need a
reboot. This parameter is a VOID* and it is the
responsibility of the test author to ensure that the
contents are well understood by all test cases that may
consume it.
@retval UNIT_TEST_PASSED The Unit test has completed and the test
case was successful.
@retval UNIT_TEST_ERROR_TEST_FAILED A test case assertion has failed.
**/
UNIT_TEST_STATUS
EFIAPI
SetSecureBootVariablesDBTOptional (
IN UNIT_TEST_CONTEXT Context
)
{
EFI_STATUS Status;
UINT8 DbDummy = 0xDE;
UINT8 DbxDummy = 0xBE;
UINT8 KekDummy = 0xEF;
UINT8 PkDummy = 0xFE;
UINT8 *Payload = NULL;
UINTN PayloadSize = sizeof (DbDummy);
SECURE_BOOT_PAYLOAD_INFO PayloadInfo = {
.DbPtr = &DbDummy,
.DbSize = sizeof (DbDummy),
.DbxPtr = &DbxDummy,
.DbxSize = sizeof (DbxDummy),
.DbtPtr = NULL,
.DbtSize = 0,
.KekPtr = &KekDummy,
.KekSize = sizeof (KekDummy),
.PkPtr = &PkDummy,
.PkSize = sizeof (PkDummy),
.SecureBootKeyName = L"Food"
};
expect_memory (MockGetVariable, VariableName, EFI_SECURE_BOOT_MODE_NAME, sizeof (EFI_SECURE_BOOT_MODE_NAME));
expect_value (MockGetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockGetVariable, *DataSize, 0);
will_return (MockGetVariable, FALSE);
Payload = AllocateCopyPool (sizeof (DbxDummy), &DbxDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE1, sizeof (EFI_IMAGE_SECURITY_DATABASE1));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbxDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &DbDummy, sizeof (DbDummy));
PayloadSize = sizeof (DbDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, VariableName, EFI_IMAGE_SECURITY_DATABASE, sizeof (EFI_IMAGE_SECURITY_DATABASE));
expect_value (MockSetVariable, VendorGuid, &gEfiImageSecurityDatabaseGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (DbDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &KekDummy, sizeof (KekDummy));
PayloadSize = sizeof (KekDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, VariableName, EFI_KEY_EXCHANGE_KEY_NAME, sizeof (EFI_KEY_EXCHANGE_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (KekDummy));
will_return (MockSetVariable, EFI_SUCCESS);
CopyMem (Payload, &PkDummy, sizeof (PkDummy));
PayloadSize = sizeof (PkDummy);
Status = CreateTimeBasedPayload (&PayloadSize, &Payload, &mDefaultPayloadTimestamp);
UT_ASSERT_NOT_EFI_ERROR (Status);
UT_ASSERT_EQUAL (PayloadSize, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
expect_memory (MockSetVariable, VariableName, EFI_PLATFORM_KEY_NAME, sizeof (EFI_PLATFORM_KEY_NAME));
expect_value (MockSetVariable, VendorGuid, &gEfiGlobalVariableGuid);
expect_value (MockSetVariable, Attributes, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS);
expect_value (MockSetVariable, DataSize, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
expect_memory (MockSetVariable, Data, Payload, VAR_AUTH_DESC_SIZE + sizeof (PkDummy));
will_return (MockSetVariable, EFI_SUCCESS);
Status = SetSecureBootVariablesToDefault (&PayloadInfo);
UT_ASSERT_NOT_EFI_ERROR (Status);
return UNIT_TEST_PASSED;
}
/**
Initialze the unit test framework, suite, and unit tests for the
SecureBootVariableLib and run the SecureBootVariableLib unit test.
@retval EFI_SUCCESS All test cases were dispatched.
@retval EFI_OUT_OF_RESOURCES There are not enough resources available to
initialize the unit tests.
**/
STATIC
EFI_STATUS
EFIAPI
UnitTestingEntry (
VOID
)
{
EFI_STATUS Status;
UNIT_TEST_FRAMEWORK_HANDLE Framework;
UNIT_TEST_SUITE_HANDLE SecureBootVarMiscTests;
UNIT_TEST_SUITE_HANDLE SecureBootVarDeleteTests;
UNIT_TEST_SUITE_HANDLE SecureBootVarEnrollTests;
Framework = NULL;
DEBUG ((DEBUG_INFO, "%a v%a\n", UNIT_TEST_APP_NAME, UNIT_TEST_APP_VERSION));
//
// Start setting up the test framework for running the tests.
//
Status = InitUnitTestFramework (&Framework, UNIT_TEST_APP_NAME, gEfiCallerBaseName, UNIT_TEST_APP_VERSION);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "Failed in InitUnitTestFramework. Status = %r\n", Status));
goto EXIT;
}
//
// Populate the SecureBootVariableLib Unit Test Suite.
//
Status = CreateUnitTestSuite (&SecureBootVarMiscTests, Framework, "SecureBootVariableLib Miscellaneous Tests", "SecureBootVariableLib.Miscellaneous", NULL, NULL);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "Failed in CreateUnitTestSuite for SecureBootVariableLib\n"));
Status = EFI_OUT_OF_RESOURCES;
goto EXIT;
}
Status = CreateUnitTestSuite (&SecureBootVarDeleteTests, Framework, "SecureBootVariableLib Deletion Tests", "SecureBootVariableLib.Deletion", NULL, NULL);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "Failed in CreateUnitTestSuite for SecureBootVariableLib\n"));
Status = EFI_OUT_OF_RESOURCES;
goto EXIT;
}
Status = CreateUnitTestSuite (&SecureBootVarEnrollTests, Framework, "SecureBootVariableLib Enrollment Tests", "SecureBootVariableLib.Enrollment", NULL, NULL);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_ERROR, "Failed in CreateUnitTestSuite for SecureBootVariableLib\n"));
Status = EFI_OUT_OF_RESOURCES;
goto EXIT;
}
//
// --------------Suite-----------Description--------------Name----------Function--------Pre---Post-------------------Context-----------
//
AddTestCase (SecureBootVarMiscTests, "SetSecureBootMode should propagate to set variable", "SetSecureBootMode", SetSecureBootModeShouldSetVar, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "GetSetupMode should propagate to get variable", "GetSetupMode", GetSetupModeShouldGetVar, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "IsSecureBootEnabled should propagate to get variable", "IsSecureBootEnabled", IsSecureBootEnableShouldGetVar, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "SecureBootCreateDataFromInput with one input cert", "SecureBootCreateDataFromInput One Cert", SecureBootCreateDataFromInputSimple, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "SecureBootCreateDataFromInput with no input cert", "SecureBootCreateDataFromInput No Cert", SecureBootCreateDataFromInputNull, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "SecureBootCreateDataFromInput with multiple input cert", "SecureBootCreateDataFromInput No Cert", SecureBootCreateDataFromInputMultiple, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "CreateTimeBasedPayload should populate descriptor data", "CreateTimeBasedPayload Normal", CreateTimeBasedPayloadShouldPopulateDescriptor, NULL, NULL, NULL);
AddTestCase (SecureBootVarMiscTests, "CreateTimeBasedPayload should fail on NULL inputs", "CreateTimeBasedPayload NULL", CreateTimeBasedPayloadShouldCheckInput, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteDb should delete DB with auth info", "DeleteDb", DeleteDbShouldDelete, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteDbx should delete DBX with auth info", "DeleteDbx", DeleteDbxShouldDelete, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteDbt should delete DBT with auth info", "DeleteDbt", DeleteDbtShouldDelete, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteKEK should delete KEK with auth info", "DeleteKEK", DeleteKEKShouldDelete, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeletePlatformKey should delete PK with auth info", "DeletePlatformKey", DeletePKShouldDelete, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteSecureBootVariables should delete properly", "DeleteSecureBootVariables Normal", DeleteSecureBootVariablesShouldDelete, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteSecureBootVariables should fail if protection disable fails", "DeleteSecureBootVariables Fail", DeleteSecureBootVariablesShouldCheckProtection, NULL, NULL, NULL);
AddTestCase (SecureBootVarDeleteTests, "DeleteSecureBootVariables should continue if any variable is not found", "DeleteSecureBootVariables Proceed", DeleteSecureBootVariablesShouldProceedWithNotFound, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "EnrollFromInput should supply with authenticated payload", "EnrollFromInput Normal", EnrollFromInputShouldComplete, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should complete", "SetSecureBootVariablesToDefault Normal", SetSecureBootVariablesShouldComplete, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should stop when already enabled", "SetSecureBootVariablesToDefault Already Started", SetSecureBootVariablesShouldStopWhenSecure, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should stop when DB failed", "SetSecureBootVariablesToDefault Fails DB", SetSecureBootVariablesShouldStopFailDB, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should stop when DBT failed", "SetSecureBootVariablesToDefault Fails DBT", SetSecureBootVariablesShouldStopFailDBT, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should stop when DBX failed", "SetSecureBootVariablesToDefault Fails DBX", SetSecureBootVariablesShouldStopFailDBX, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should stop when KEK failed", "SetSecureBootVariablesToDefault Fails KEK", SetSecureBootVariablesShouldStopFailKEK, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should stop when PK failed", "SetSecureBootVariablesToDefault Fails PK", SetSecureBootVariablesShouldStopFailPK, NULL, NULL, NULL);
AddTestCase (SecureBootVarEnrollTests, "SetSecureBootVariablesToDefault should only be optional", "SetSecureBootVariablesToDefault DBT Optional", SetSecureBootVariablesDBTOptional, NULL, NULL, NULL);
//
// Execute the tests.
//
Status = RunAllTestSuites (Framework);
EXIT:
if (Framework) {
FreeUnitTestFramework (Framework);
}
return Status;
}
/**
Standard POSIX C entry point for host based unit test execution.
**/
int
main (
int argc,
char *argv[]
)
{
return UnitTestingEntry ();
}