Files
system76-edk2/CryptoPkg/Test/UnitTest/Library/BaseCryptLib/TestBaseCryptLib.h
Matthew Carlson 694bfd6ff5 CryptoPkg: BaseCryptLib: Add unit tests (Host and Shell based)
This adds a new INF for BaseCryptLib suitable for
host based environments. It adds a host based unit test for
BaseCryptLib that can also be built as a shell based Unit Test.

In addition, this also adds a UnitTestHostCrtWrapper.c file, which provides
some of the functionality not provided by the default host based unit test
system that OpenSSL expects. This is used by UnitTestHostBaseCryptLib, a
version of the BaseCryptLib meant specifically for host based unit testing.

Cc: Jian J Wang <jian.j.wang@intel.com>
Cc: Xiaoyu Lu <xiaoyux.lu@intel.com>
Cc: Jiewen Yao <jiewen.yao@intel.com>
Cc: Guomin Jiang <guomin.jiang@intel.com>
Signed-off-by: Matthew Carlson <matthewfcarlson@gmail.com>
Reviewed-by: Jiewen Yao <jiewen.yao@intel.com>
2020-10-18 00:49:58 +00:00

122 lines
2.7 KiB
C

/** @file
Application for Cryptographic Primitives Validation.
Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#ifndef __CRYPTEST_H__
#define __CRYPTEST_H__
#include <PiPei.h>
#include <Uefi.h>
#include <Library/UefiLib.h>
#include <Library/DebugLib.h>
#include <Library/UnitTestLib.h>
#include <Library/PrintLib.h>
#include <Library/BaseCryptLib.h>
#include <Library/BaseLib.h>
#include <Library/BaseMemoryLib.h>
#include <Library/MemoryAllocationLib.h>
//#include <UnitTestTypes.h>
#include <Library/UnitTestLib.h>
//#include <Library/UnitTestAssertLib.h>
#define UNIT_TEST_NAME "BaseCryptLib Unit Test"
#define UNIT_TEST_VERSION "1.0"
typedef struct {
CHAR8 *Description;
CHAR8 *ClassName;
UNIT_TEST_FUNCTION Func;
UNIT_TEST_PREREQUISITE PreReq;
UNIT_TEST_CLEANUP CleanUp;
UNIT_TEST_CONTEXT Context;
} TEST_DESC;
typedef struct {
CHAR8 *Title;
CHAR8 *Package;
UNIT_TEST_SUITE_SETUP Sup;
UNIT_TEST_SUITE_TEARDOWN Tdn;
UINTN *TestNum;
TEST_DESC *TestDesc;
} SUITE_DESC;
extern UINTN mPkcs7EkuTestNum;
extern TEST_DESC mPkcs7EkuTest[];
extern UINTN mHashTestNum;
extern TEST_DESC mHashTest[];
extern UINTN mHmacTestNum;
extern TEST_DESC mHmacTest[];
extern UINTN mBlockCipherTestNum;
extern TEST_DESC mBlockCipherTest[];
extern UINTN mRsaTestNum;
extern TEST_DESC mRsaTest[];
extern UINTN mRsaCertTestNum;
extern TEST_DESC mRsaCertTest[];
extern UINTN mPkcs7TestNum;
extern TEST_DESC mPkcs7Test[];
extern UINTN mPkcs5TestNum;
extern TEST_DESC mPkcs5Test[];
extern UINTN mAuthenticodeTestNum;
extern TEST_DESC mAuthenticodeTest[];
extern UINTN mImageTimestampTestNum;
extern TEST_DESC mImageTimestampTest[];
extern UINTN mDhTestNum;
extern TEST_DESC mDhTest[];
extern UINTN mPrngTestNum;
extern TEST_DESC mPrngTest[];
extern UINTN mOaepTestNum;
extern TEST_DESC mOaepTest[];
/** Creates a framework you can use */
EFI_STATUS
EFIAPI
CreateUnitTest (
IN CHAR8* UnitTestName,
IN CHAR8* UnitTestVersion,
IN OUT UNIT_TEST_FRAMEWORK_HANDLE* Framework
);
/**
Validate UEFI-OpenSSL DH Interfaces.
@retval EFI_SUCCESS Validation succeeded.
@retval EFI_ABORTED Validation failed.
**/
EFI_STATUS
ValidateCryptDh (
VOID
);
/**
Validate UEFI-OpenSSL pseudorandom number generator interfaces.
@retval EFI_SUCCESS Validation succeeded.
@retval EFI_ABORTED Validation failed.
**/
EFI_STATUS
ValidateCryptPrng (
VOID
);
#endif