未验证 提交 0d4e2b02 编写于 作者: O openharmony_ci 提交者: Gitee

!1626 设备认证依赖算法测试用例

Merge pull request !1626 from code4lala/deviceauth_alg_xts_test_case
......@@ -50,16 +50,8 @@ hctest_suite("ActsSecurityHichainBasicDeps") {
"UTILS_FILE_IMPLEMENTED=1",
"TEST_PTHREAD_CREATE_DETACHED=0",
"TEST_HC_FILE_OPEN_SERIES=1",
"TEST_HKDF_WITH_KEY_ALIAS_TRUE=1",
"TEST_IMPORT_ASYMMETRIC_KEY=1",
"TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE=1",
"TEST_HASH_TO_POINT=1",
"TEST_GENERATE_KEY_PAIR_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET=1",
"TEST_BIG_NUM_EXP_MOD=1",
]
defines += DEVICEAUTH_BASIC_DEPS_ALGORITHM_DEFINES
if (defined(ohos_lite)) {
include_dirs += [
......@@ -76,11 +68,42 @@ hctest_suite("ActsSecurityHichainBasicDeps") {
defines -= [
"FLASH_START_ADDRESS_HICHAIN=0",
"TEST_HC_FILE_OPEN_SERIES=1",
"TEST_HKDF_WITH_KEY_ALIAS_TRUE=1",
"TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE=1",
"TEST_HASH_TO_POINT=1",
"TEST_GENERATE_KEY_PAIR_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET=1",
"TEST_GENERATE_KEY_PAIR=1",
"TEST_EXPORT_PUBLIC_KEY=1",
"TEST_ALGORITHM_SIGN=1",
"TEST_ALGORITHM_VERIFY=1",
"TEST_IMPORT_PUBLIC_KEY=1",
"TEST_CHECK_KEY_EXIST=1",
"TEST_DELETE_KEY=1",
"TEST_AES_GCM_ENCRYPT=1",
"TEST_AES_GCM_DECRYPT=1",
]
defines += [
"FLASH_START_ADDRESS_HICHAIN=0x1F6000",
"TEST_HC_FILE_OPEN_SERIES=0",
"TEST_HKDF_WITH_KEY_ALIAS_TRUE=0",
"TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE=0",
"TEST_HASH_TO_POINT=0",
"TEST_GENERATE_KEY_PAIR_WITH_STORAGE=0",
"TEST_AGREE_SHARED_SECRET_WITH_STORAGE=0",
"TEST_AGREE_SHARED_SECRET=0",
"TEST_GENERATE_KEY_PAIR=0",
"TEST_EXPORT_PUBLIC_KEY=0",
"TEST_ALGORITHM_SIGN=0",
"TEST_ALGORITHM_VERIFY=0",
"TEST_IMPORT_PUBLIC_KEY=0",
"TEST_CHECK_KEY_EXIST=0",
"TEST_DELETE_KEY=0",
"TEST_AES_GCM_ENCRYPT=0",
"TEST_AES_GCM_DECRYPT=0",
]
defines += [ "DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY=1" ]
}
if (board_name == "hispark_pegasus") {
# 3861
......@@ -90,7 +113,11 @@ hctest_suite("ActsSecurityHichainBasicDeps") {
"TEST_GENERATE_KEY_PAIR_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET=1",
"TEST_BIG_NUM_EXP_MOD=1",
"TEST_GENERATE_KEY_PAIR=1",
"TEST_EXPORT_PUBLIC_KEY=1",
"TEST_ALGORITHM_SIGN=1",
"TEST_ALGORITHM_VERIFY=1",
"TEST_IMPORT_PUBLIC_KEY=1",
]
defines += [
"TEST_HKDF_WITH_KEY_ALIAS_TRUE=0",
......@@ -98,7 +125,11 @@ hctest_suite("ActsSecurityHichainBasicDeps") {
"TEST_GENERATE_KEY_PAIR_WITH_STORAGE=0",
"TEST_AGREE_SHARED_SECRET_WITH_STORAGE=0",
"TEST_AGREE_SHARED_SECRET=0",
"TEST_BIG_NUM_EXP_MOD=0",
"TEST_GENERATE_KEY_PAIR=0",
"TEST_EXPORT_PUBLIC_KEY=0",
"TEST_ALGORITHM_SIGN=0",
"TEST_ALGORITHM_VERIFY=0",
"TEST_IMPORT_PUBLIC_KEY=0",
]
}
} else {
......
## wifiiot_hispark_pegasus
1. compile command:
``` bash
cd test/xts/tools/lite
./build.sh product=wifiiot xts=acts target=//test/xts/acts/security_lite/deviceauth_basic_deps:ActsSecurityHichainBasicDeps
```
......@@ -40,3 +40,27 @@ DEVICEAUTH_BASIC_DEPS_INC = [
"//base/security/deviceauth/common_lib/interfaces",
"//base/security/deviceauth/interfaces/innerkits",
]
DEVICEAUTH_BASIC_DEPS_ALGORITHM_DEFINES = [
"TEST_HKDF_WITH_KEY_ALIAS_TRUE=1",
"TEST_IMPORT_SYMMETRIC_KEY=1",
"TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE=1",
"TEST_HASH_TO_POINT=1",
"TEST_GENERATE_KEY_PAIR_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET_WITH_STORAGE=1",
"TEST_AGREE_SHARED_SECRET=1",
"TEST_BIG_NUM_EXP_MOD=1",
"TEST_EXPORT_IMPORT_SIGN_VERIFY_ED25519=1",
"TEST_EXPORT_IMPORT_SIGN_VERIFY_P256=1",
"TEST_BIG_NUM_COMPARE=1",
"TEST_GENERATE_KEY_PAIR=1",
"TEST_EXPORT_PUBLIC_KEY=1",
"TEST_ALGORITHM_SIGN=1",
"TEST_ALGORITHM_VERIFY=1",
"TEST_IMPORT_PUBLIC_KEY=1",
"TEST_CHECK_DL_PUBLIC_KEY=1",
"TEST_CHECK_KEY_EXIST=1",
"TEST_DELETE_KEY=1",
"TEST_AES_GCM_ENCRYPT=1",
"TEST_AES_GCM_DECRYPT=1",
]
......@@ -20,6 +20,7 @@
#include <hal_error.h>
#include <hctest.h>
#include <stdlib.h>
#include <string_util.h>
#include <unistd.h>
#include "hc_alg_test_case.h"
......@@ -45,19 +46,25 @@ static uint32_t CountZero(const uint8_t *buffer, uint32_t length)
static void FillRandom(uint8_t *msg, uint32_t setZeroLength, uint32_t randomLength)
{
if (randomLength < 1) {
return;
}
int res;
res = memset_s(msg, setZeroLength, 0, setZeroLength);
TEST_ASSERT_EQUAL(EOK, res);
// generate random message
if (randomLength == 1) {
msg[0] = rand() % (UINT8_MAX - 1) + 1;
} else {
for (uint32_t i = 0; i < randomLength; ++i) {
for (uint32_t i = 1; i < randomLength; ++i) {
msg[i] = rand() % UINT8_MAX;
}
enum {
// ignore rand correctness if the random length is equal or less than 3
RANDOM_CONSECUTIVE_ZERO_LENGTH_LIMIT = 3,
};
if (randomLength <= RANDOM_CONSECUTIVE_ZERO_LENGTH_LIMIT + 1) {
return;
}
TEST_ASSERT_NOT_EQUAL(randomLength, CountZero(msg, randomLength));
TEST_ASSERT_NOT_EQUAL(randomLength - 1, CountZero(msg + 1, randomLength - 1));
}
// Note: sha256 and sha256Compare will be set to all zero
......@@ -244,10 +251,9 @@ static void TestComputeHmacWithIsAliasTrue(const AlgLoader *loader,
Uint8Buff *msg, Uint8Buff *hmacKeyBuff, Uint8Buff *outHmacBuff)
#if TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE
{
TEST_ASSERT_NOT_NULL(loader->importAsymmetricKey);
TEST_ASSERT_NOT_NULL(loader->deleteKey);
if (loader->importAsymmetricKey == NULL || loader->deleteKey == NULL) {
LOGE("importAsymmetricKey or deleteKey is NULL, can not test computeHmac with isAlias true");
TEST_ASSERT_NOT_NULL(loader->importSymmetricKey);
if (!loader->importSymmetricKey) {
LOGE("importSymmetricKey is NULL, can not test computeHmac with isAlias true");
return;
}
LOGI("test hmac for isAlias true");
......@@ -260,19 +266,24 @@ static void TestComputeHmacWithIsAliasTrue(const AlgLoader *loader,
.userType = DEVICE_TYPE_ACCESSORY,
.pairType = PAIR_TYPE_BIND,
};
int res = loader->importAsymmetricKey(hmacKeyBuff, hmacKeyBuff, &info);
int res = loader->importSymmetricKey(hmacKeyBuff, hmacKeyBuff, KEY_PURPOSE_MAC, &info);
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
TestComputeHmacInner(loader, hmacKeyBuff, msg, outHmacBuff, true);
// delete key after the test
if (loader->deleteKey) {
LOGD("test deleteKey");
res = loader->deleteKey(hmacKeyBuff);
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
}
}
#else // TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE
{
LOGE("no TEST_COMPUTEHMAC_WITH_ISALIAS_TRUE, do not test computeHmac with isAlias true");
TEST_ASSERT_TRUE(loader->importAsymmetricKey == NULL || loader->deleteKey == NULL);
LOG_ERROR_IF_POINTER_NULL(loader->importAsymmetricKey);
LOG_ERROR_IF_POINTER_NULL(loader->deleteKey);
#if (defined(DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY) && DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY)
(void)(loader);
#else // DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY
TEST_ASSERT_NULL(loader->importSymmetricKey);
#endif // DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY
(void)(msg);
(void)(hmacKeyBuff);
(void)(outHmacBuff);
......@@ -423,9 +434,8 @@ static void TestComputeHkdfWithKeyAliasTrue(
LOGI("pake psk derive secret keyAlias true");
TEST_ASSERT_NOT_NULL(loader->generateKeyPairWithStorage);
TEST_ASSERT_NOT_NULL(loader->agreeSharedSecretWithStorage);
TEST_ASSERT_NOT_NULL(loader->deleteKey);
if (!loader->generateKeyPairWithStorage || !loader->agreeSharedSecretWithStorage || !loader->deleteKey) {
LOGE("generateKeyPairWithStorage or agreeSharedSecretWithStorage or deleteKey pointer is NULL! "
if (!loader->generateKeyPairWithStorage || !loader->agreeSharedSecretWithStorage) {
LOGE("generateKeyPairWithStorage or agreeSharedSecretWithStorage pointer is NULL! "
"can not test hkdf with alias true!");
return;
}
......@@ -452,9 +462,12 @@ static void TestComputeHkdfWithKeyAliasTrue(
loader, &privKeyPairAlias, &pubKeyPairAlias, &extraInfo, &sharedKeyAlias);
TestComputeHkdfWithKeyAliasTrueThirdStep(
loader, argument, &sharedKeyAlias);
if (loader->deleteKey) {
LOGD("test deleteKey");
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&privKeyPairAlias));
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&pubKeyPairAlias));
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&sharedKeyAlias));
}
LOGD("At last, free all memories allocated");
free(privKeyPairAlias.val);
......@@ -472,11 +485,9 @@ static void TestComputeHkdfWithKeyAliasTrue(
struct HkdfArgument *argument)
{
LOGE("no TEST_HKDF_WITH_KEY_ALIAS_TRUE, do not test hkdf with key alias true");
TEST_ASSERT_TRUE(loader->generateKeyPairWithStorage == NULL || loader->agreeSharedSecretWithStorage == NULL ||
loader->deleteKey == NULL);
TEST_ASSERT_TRUE(loader->generateKeyPairWithStorage == NULL || loader->agreeSharedSecretWithStorage == NULL);
LOG_ERROR_IF_POINTER_NULL(loader->generateKeyPairWithStorage);
LOG_ERROR_IF_POINTER_NULL(loader->agreeSharedSecretWithStorage);
LOG_ERROR_IF_POINTER_NULL(loader->deleteKey);
(void)(argument);
}
#endif // TEST_HKDF_WITH_KEY_ALIAS_TRUE // }
......@@ -543,30 +554,30 @@ static void TestComputeHkdf(const AlgLoader *loader)
TestComputeHkdfCorrectness(loader, &argument);
}
#if TEST_IMPORT_ASYMMETRIC_KEY // {
#if TEST_IMPORT_SYMMETRIC_KEY // {
enum {
WAIT_FOR_WATCH_DOG = 1,
};
static void TestImportAsymmetricKey(const AlgLoader *loader)
static void TestImportSymmetricKey(const AlgLoader *loader)
{
TEST_ASSERT_NOT_NULL(loader->importAsymmetricKey);
if (loader->importAsymmetricKey == NULL) {
LOGE("importAsymmetricKey pointer is NULL! will not test!");
TEST_ASSERT_NOT_NULL(loader->importSymmetricKey);
if (loader->importSymmetricKey == NULL) {
LOGE("importSymmetricKey pointer is NULL! will not test!");
return;
}
int res;
const uint32_t authIdLenArray[] = { TEST_IMPORT_ASYMMETRIC_KEY_AUTH_ID_LENGTH_32,
TEST_IMPORT_ASYMMETRIC_KEY_AUTH_ID_LENGTH_64 };
const uint32_t authIdLenArray[] = { TEST_IMPORT_SYMMETRIC_KEY_AUTH_ID_LENGTH_32,
TEST_IMPORT_SYMMETRIC_KEY_AUTH_ID_LENGTH_64 };
for (uint32_t i = 0; i < ARRAY_SIZE(authIdLenArray); ++i) {
for (
uint32_t j = IMPORT_ASYMMETRIC_KEY_KEYALIAS_LEN_MIN;
j <= IMPORT_ASYMMETRIC_KEY_KEYALIAS_LEN_MAX;
uint32_t j = IMPORT_SYMMETRIC_KEY_KEYALIAS_LEN_MIN;
j <= IMPORT_SYMMETRIC_KEY_KEYALIAS_LEN_MAX;
++j) {
LOGD("auth id length = %d, msg length = %d", authIdLenArray[i], j);
LOGD("auth id length = %u, msg length = %u", authIdLenArray[i], j);
Uint8Buff keyAlias = { (uint8_t *)malloc(j), j };
Uint8Buff authToken = { (uint8_t *)malloc(IMPORT_ASYMMETRIC_KEY_AUTHTOKEN_LEN),
IMPORT_ASYMMETRIC_KEY_AUTHTOKEN_LEN };
Uint8Buff authToken = { (uint8_t *)malloc(IMPORT_SYMMETRIC_KEY_AUTHTOKEN_LEN),
IMPORT_SYMMETRIC_KEY_AUTHTOKEN_LEN };
ExtraInfo extraInfo = { { (uint8_t *)malloc(authIdLenArray[i]), authIdLenArray[i] },
DEVICE_TYPE_ACCESSORY, PAIR_TYPE_BIND };
TEST_ASSERT_NOT_NULL(keyAlias.val);
......@@ -575,14 +586,19 @@ static void TestImportAsymmetricKey(const AlgLoader *loader)
FillRandom(keyAlias.val, keyAlias.length, keyAlias.length);
FillRandom(authToken.val, authToken.length, authToken.length);
FillRandom(extraInfo.authId.val, extraInfo.authId.length, extraInfo.authId.length);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->importAsymmetricKey(&keyAlias, &authToken, &extraInfo));
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->importSymmetricKey(&keyAlias, &authToken, KEY_PURPOSE_MAC, &extraInfo));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
LOGD("test exist");
if (loader->checkKeyExist) {
LOGD("test checkKeyExist");
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkKeyExist(&keyAlias));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
}
if (loader->deleteKey) {
LOGD("test delete");
RUN_AND_PRINT_ELAPSED_TIME(res, loader->deleteKey(&keyAlias));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
}
free(keyAlias.val);
keyAlias.val = (uint8_t *)NULL;
free(authToken.val);
......@@ -594,16 +610,16 @@ static void TestImportAsymmetricKey(const AlgLoader *loader)
sleep(WAIT_FOR_WATCH_DOG);
}
}
#else // TEST_IMPORT_ASYMMETRIC_KEY // } {
static void TestImportAsymmetricKey(const AlgLoader *loader)
#else // TEST_IMPORT_SYMMETRIC_KEY // } {
static void TestImportSymmetricKey(const AlgLoader *loader)
{
LOGE("no TEST_IMPORT_ASYMMETRIC_KEY, do not test importAsymmetricKey");
TEST_ASSERT_NULL(loader->importAsymmetricKey);
LOG_ERROR_IF_POINTER_NULL(loader->importAsymmetricKey);
LOGE("no TEST_IMPORT_SYMMETRIC_KEY, do not test importSymmetricKey");
TEST_ASSERT_NULL(loader->importSymmetricKey);
}
#endif // TEST_IMPORT_ASYMMETRIC_KEY // }
#endif // TEST_IMPORT_SYMMETRIC_KEY // }
static void TestCheckKeyExist(const AlgLoader *loader)
#if TEST_CHECK_KEY_EXIST
{
TEST_ASSERT_NOT_NULL(loader->checkKeyExist);
if (loader->checkKeyExist == NULL) {
......@@ -620,8 +636,15 @@ static void TestCheckKeyExist(const AlgLoader *loader)
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkKeyExist(&keyAlias));
TEST_ASSERT_NOT_EQUAL(HAL_SUCCESS, res);
}
#else // TEST_CHECK_KEY_EXIST
{
LOGE("no TEST_CHECK_KEY_EXIST, do not test checkKeyExist");
TEST_ASSERT_NULL(loader->checkKeyExist);
}
#endif // TEST_CHECK_KEY_EXIST
static void TestDeleteKey(const AlgLoader *loader)
#if TEST_DELETE_KEY
{
TEST_ASSERT_NOT_NULL(loader->deleteKey);
if (loader->deleteKey == NULL) {
......@@ -638,8 +661,15 @@ static void TestDeleteKey(const AlgLoader *loader)
RUN_AND_PRINT_ELAPSED_TIME(res, loader->deleteKey(&keyAlias));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
}
#else // TEST_DELETE_KEY
{
LOGE("no TEST_DELETE_KEY, do not test deleteKey");
TEST_ASSERT_NULL(loader->deleteKey);
}
#endif // TEST_DELETE_KEY
static void TestAesGcmEncrypt(const AlgLoader *loader)
#if TEST_AES_GCM_ENCRYPT
{
LOGI("begin to test the AES-GCM algorithm encryption");
TEST_ASSERT_NOT_NULL(loader->aesGcmEncrypt);
......@@ -674,8 +704,15 @@ static void TestAesGcmEncrypt(const AlgLoader *loader)
free(nonce);
free(cipher);
}
#else // TEST_AES_GCM_ENCRYPT
{
LOGE("no TEST_AES_GCM_ENCRYPT, do not test aesGcmEncrypt");
TEST_ASSERT_NULL(loader->aesGcmEncrypt);
}
#endif // TEST_AES_GCM_ENCRYPT
static void TestAesGcmDecrypt(const AlgLoader *loader)
#if TEST_AES_GCM_DECRYPT
{
LOGI("begin to test the AES-GCM algorithm decryption");
TEST_ASSERT_NOT_NULL(loader->aesGcmDecrypt);
......@@ -710,6 +747,12 @@ static void TestAesGcmDecrypt(const AlgLoader *loader)
free(nonce);
free(plain);
}
#else // TEST_AES_GCM_DECRYPT
{
LOGE("no TEST_AES_GCM_DECRYPT, do not test aesGcmDecrypt");
TEST_ASSERT_NULL(loader->aesGcmDecrypt);
}
#endif // TEST_AES_GCM_DECRYPT
static void TestHashToPoint(const AlgLoader *loader)
#if TEST_HASH_TO_POINT
......@@ -737,7 +780,6 @@ static void TestHashToPoint(const AlgLoader *loader)
{
LOGE("no TEST_HASH_TO_POINT, do not test loader->hashToPoint!");
TEST_ASSERT_NULL(loader->hashToPoint);
LOG_ERROR_IF_POINTER_NULL(loader->hashToPoint);
}
#endif // TEST_HASH_TO_POINT
......@@ -785,9 +827,8 @@ static void TestAgreeSharedSecretWithStorage(const AlgLoader *loader)
TEST_ASSERT_NOT_NULL(loader->agreeSharedSecretWithStorage);
TEST_ASSERT_NOT_NULL(loader->computeHkdf);
TEST_ASSERT_NOT_NULL(loader->generateKeyPairWithStorage);
TEST_ASSERT_NOT_NULL(loader->deleteKey);
if (!loader->agreeSharedSecretWithStorage || !loader->computeHkdf
|| !loader->generateKeyPairWithStorage || !loader->deleteKey) {
|| !loader->generateKeyPairWithStorage) {
LOGE("one of required function pointer is NULL! will not test!");
return;
}
......@@ -825,10 +866,13 @@ static void TestAgreeSharedSecretWithStorage(const AlgLoader *loader)
TEST_ASSERT_EQUAL(HAL_SUCCESS, ret);
VerifyAgreeSharedSecretWithStorage(loader, &sharedKeyAlias1, &sharedKeyAlias2);
if (loader->deleteKey) {
LOGD("test deleteKey");
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&sharedKeyAlias1));
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&sharedKeyAlias2));
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&keyAliasA));
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&keyAliasB));
}
}
#else // TEST_AGREE_SHARED_SECRET_WITH_STORAGE
static void TestAgreeSharedSecretWithStorage(const AlgLoader *loader)
......@@ -836,12 +880,10 @@ static void TestAgreeSharedSecretWithStorage(const AlgLoader *loader)
LOGE("no TEST_AGREE_SHARED_SECRET_WITH_STORAGE, do not test loader->agreeSharedSecretWithStorage!");
TEST_ASSERT_TRUE(loader->agreeSharedSecretWithStorage == NULL ||
loader->computeHkdf == NULL ||
loader->generateKeyPairWithStorage == NULL ||
loader->deleteKey == NULL);
loader->generateKeyPairWithStorage == NULL);
LOG_ERROR_IF_POINTER_NULL(loader->agreeSharedSecretWithStorage);
LOG_ERROR_IF_POINTER_NULL(loader->computeHkdf);
LOG_ERROR_IF_POINTER_NULL(loader->generateKeyPairWithStorage);
LOG_ERROR_IF_POINTER_NULL(loader->deleteKey);
}
#endif // TEST_AGREE_SHARED_SECRET_WITH_STORAGE
......@@ -887,7 +929,6 @@ static void TestAgreeSharedSecret(const AlgLoader *loader)
{
LOGE("no TEST_AGREE_SHARED_SECRET, do not test loader->agreeSharedSecret");
TEST_ASSERT_NULL(loader->agreeSharedSecret);
LOG_ERROR_IF_POINTER_NULL(loader->agreeSharedSecret);
}
#endif // TEST_AGREE_SHARED_SECRET
......@@ -895,10 +936,8 @@ static void TestGenerateKeyPairWithStorage(const AlgLoader *loader)
#if TEST_GENERATE_KEY_PAIR_WITH_STORAGE
{
TEST_ASSERT_NOT_NULL(loader->generateKeyPairWithStorage);
TEST_ASSERT_NOT_NULL(loader->checkKeyExist);
TEST_ASSERT_NOT_NULL(loader->deleteKey);
if (!loader->generateKeyPairWithStorage || !loader->checkKeyExist || !loader->deleteKey) {
LOGE("one of required function pointer is NULL! will not test!");
if (!loader->generateKeyPairWithStorage) {
LOGE("generateKeyPairWithStorage pointer is NULL! will not test!");
return;
}
......@@ -918,20 +957,21 @@ static void TestGenerateKeyPairWithStorage(const AlgLoader *loader)
RUN_AND_PRINT_ELAPSED_TIME(ret,
loader->generateKeyPairWithStorage(&keyAlias, ED25519_KEY_BYTE_LEN, ED25519, &extraInfo));
TEST_ASSERT_EQUAL(HAL_SUCCESS, ret);
if (loader->checkKeyExist) {
LOGD("test checkKeyExist");
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->checkKeyExist(&keyAlias));
}
if (loader->deleteKey) {
LOGD("test deleteKey");
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&keyAlias));
}
free(extraInfo.authId.val);
}
#else // TEST_GENERATE_KEY_PAIR_WITH_STORAGE
{
LOGE("no TEST_GENERATE_KEY_PAIR_WITH_STORAGE, do not test loader->generateKeyPairWithStorage!");
TEST_ASSERT_TRUE(loader->generateKeyPairWithStorage == NULL ||
loader->checkKeyExist == NULL ||
loader->deleteKey == NULL);
LOG_ERROR_IF_POINTER_NULL(loader->generateKeyPairWithStorage);
LOG_ERROR_IF_POINTER_NULL(loader->checkKeyExist);
LOG_ERROR_IF_POINTER_NULL(loader->deleteKey);
TEST_ASSERT_NULL(loader->generateKeyPairWithStorage);
}
#endif // TEST_GENERATE_KEY_PAIR_WITH_STORAGE
......@@ -956,7 +996,7 @@ static void TestBigNumExpMod(const AlgLoader *loader)
TEST_ASSERT_EQUAL(EOK, memset_s(modResult.val, primeLength, 0, primeLength));
int ret;
LOGI("test the big num case: base = %d, exp = %d, prime = %d", baseLength, expLength, primeLength);
LOGI("test the big num case: base = %u, exp = %u, prime = %u", baseLength, expLength, primeLength);
RUN_AND_PRINT_ELAPSED_TIME(ret, loader->bigNumExpMod(&base, &exp, BIG_NUM_TEST_CASES[i].prime, &modResult));
TEST_ASSERT_EQUAL(HAL_SUCCESS, ret);
TEST_ASSERT_EQUAL_HEX8_ARRAY(BIG_NUM_TEST_CASES[i].result, modResult.val, primeLength);
......@@ -968,10 +1008,588 @@ static void TestBigNumExpMod(const AlgLoader *loader)
{
LOGE("no TEST_BIG_NUM_EXP_MOD, do not test loader->bigNumExpMod!");
TEST_ASSERT_NULL(loader->bigNumExpMod);
LOG_ERROR_IF_POINTER_NULL(loader->bigNumExpMod);
}
#endif // TEST_BIG_NUM_EXP_MOD
static void TestGenerateKeyPair(const AlgLoader *loader)
#if TEST_GENERATE_KEY_PAIR
{
TEST_ASSERT_NOT_NULL(loader->generateKeyPair);
LOGE("nobody use generateKeyPair, do not test");
}
#else // TEST_GENERATE_KEY_PAIR
{
TEST_ASSERT_NULL(loader->generateKeyPair);
LOGE("no TEST_GENERATE_KEY_PAIR, do not test generateKeyPair");
}
#endif // TEST_GENERATE_KEY_PAIR
#if (TEST_EXPORT_PUBLIC_KEY || TEST_IMPORT_PUBLIC_KEY || TEST_ALGORITHM_SIGN || TEST_ALGORITHM_VERIFY)
struct TestExportImportSignVerifyParam {
ExtraInfo extInfo;
Uint8Buff keyAlias;
Uint8Buff outPubKey;
Uint8Buff anotherKeyAlias;
Uint8Buff messages[ARRAY_SIZE(TEST_SIGN_MSG_LENGTHES)];
Uint8Buff signatures[ARRAY_SIZE(TEST_SIGN_MSG_LENGTHES)];
Uint8Buff anotherOutPk;
};
static void TestExportImportSignVerifyPrepareResources(struct TestExportImportSignVerifyParam *param)
{
param->extInfo.authId.length = TEST_EX_IM_SN_VF_EXTRA_INFO_AUTH_ID_LENGTH;
param->extInfo.authId.val = (uint8_t *)malloc(param->extInfo.authId.length);
param->extInfo.userType = DEVICE_TYPE_ACCESSORY;
param->extInfo.pairType = PAIR_TYPE_BIND;
TEST_ASSERT_NOT_NULL(param->extInfo.authId.val);
FillRandom(param->extInfo.authId.val, param->extInfo.authId.length, param->extInfo.authId.length);
param->keyAlias.length = TEST_EX_IM_SN_VF_KEY_ALIAS_LENGTH;
param->keyAlias.val = (uint8_t *)malloc(param->keyAlias.length);
TEST_ASSERT_NOT_NULL(param->keyAlias.val);
FillRandom(param->keyAlias.val, param->keyAlias.length, param->keyAlias.length);
param->outPubKey.length = TEST_EX_IM_SN_VF_OUT_PUB_KEY_LENGTH;
param->outPubKey.val = (uint8_t *)malloc(param->outPubKey.length);
TEST_ASSERT_NOT_NULL(param->outPubKey.val);
TEST_ASSERT_EQUAL(EOK, memset_s(param->outPubKey.val, param->outPubKey.length, 0, param->outPubKey.length));
param->anotherKeyAlias.length = TEST_EX_IM_SN_VF_KEY_ALIAS_LENGTH;
param->anotherKeyAlias.val = (uint8_t *)malloc(param->anotherKeyAlias.length);
TEST_ASSERT_NOT_NULL(param->anotherKeyAlias.val);
do {
FillRandom(param->anotherKeyAlias.val, param->anotherKeyAlias.length, param->anotherKeyAlias.length);
} while (memcmp(param->keyAlias.val, param->anotherKeyAlias.val, TEST_EX_IM_SN_VF_KEY_ALIAS_LENGTH) == 0);
for (uint32_t i = 0; i < ARRAY_SIZE(TEST_SIGN_MSG_LENGTHES); ++i) {
param->messages[i].length = TEST_SIGN_MSG_LENGTHES[i];
param->messages[i].val = (uint8_t *)malloc(param->messages[i].length);
TEST_ASSERT_NOT_NULL(param->messages[i].val);
FillRandom(param->messages[i].val, param->messages[i].length, param->messages[i].length);
param->signatures[i].length = TEST_SIGN_SIGNATURE_LENGTH;
param->signatures[i].val = (uint8_t *)malloc(param->signatures[i].length);
TEST_ASSERT_NOT_NULL(param->signatures[i].val);
TEST_ASSERT_EQUAL(EOK,
memset_s(param->signatures[i].val, param->signatures[i].length, 0, param->signatures[i].length));
}
param->anotherOutPk.length = TEST_EX_IM_SN_VF_OUT_PUB_KEY_LENGTH;
param->anotherOutPk.val = (uint8_t *)malloc(param->anotherOutPk.length);
TEST_ASSERT_NOT_NULL(param->anotherOutPk.val);
TEST_ASSERT_EQUAL(EOK,
memset_s(param->anotherOutPk.val, param->anotherOutPk.length, 0, param->anotherOutPk.length));
}
static void TestExportImportSignVerifyInnerVerfiyNormalAndAbnormalCases(
const AlgLoader *loader, const Algorithm alg, struct TestExportImportSignVerifyParam *param)
{
int res;
for (uint32_t i = 0; i < ARRAY_SIZE(TEST_SIGN_MSG_LENGTHES); ++i) {
// test normal case
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->verify(&param->anotherOutPk, &param->messages[i], alg, &param->signatures[i], false));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
// test tamper message
uint8_t originMsg = param->messages[i].val[0];
param->messages[i].val[0] = ((originMsg == UINT8_MAX) ? 0 : (originMsg + 1));
TEST_ASSERT_NOT_EQUAL(originMsg, param->messages[i].val[0]);
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->verify(&param->anotherOutPk, &param->messages[i], alg, &param->signatures[i], false));
TEST_ASSERT_NOT_EQUAL(HAL_SUCCESS, res);
param->messages[i].val[0] = originMsg;
// test normal case
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->verify(&param->anotherOutPk, &param->messages[i], alg, &param->signatures[i], false));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
// test tamper signature
uint8_t originSig = param->signatures[i].val[0];
param->signatures[i].val[0] = ((originSig == UINT8_MAX) ? 0 : (originSig + 1));
TEST_ASSERT_NOT_EQUAL(originSig, param->signatures[i].val[0]);
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->verify(&param->anotherOutPk, &param->messages[i], alg, &param->signatures[i], false));
TEST_ASSERT_NOT_EQUAL(HAL_SUCCESS, res);
param->signatures[i].val[0] = originSig;
// test normal case
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->verify(&param->anotherOutPk, &param->messages[i], alg, &param->signatures[i], false));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
}
}
static void TestExportImportSignVerifyInner(
const AlgLoader *loader, const Algorithm alg, struct TestExportImportSignVerifyParam *param)
{
int res;
// 1. generate one public private key pair
TEST_ASSERT_EQUAL(HAL_SUCCESS,
loader->generateKeyPairWithStorage(&param->keyAlias, TEST_EX_IM_SN_VF_KEY_LENGTH, alg, &param->extInfo));
// 2. export the public key which is generated in the first step
RUN_AND_PRINT_ELAPSED_TIME(res, loader->exportPublicKey(&param->keyAlias, &param->outPubKey));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
// 3. import the public key which is exported in the second step with a different name
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->importPublicKey(&param->anotherKeyAlias, &param->outPubKey, alg, &param->extInfo));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
// 4. sign with the public key which is generated in the first step
for (uint32_t i = 0; i < ARRAY_SIZE(TEST_SIGN_MSG_LENGTHES); ++i) {
RUN_AND_PRINT_ELAPSED_TIME(res,
loader->sign(&param->keyAlias, &param->messages[i], alg, &param->signatures[i], true));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
TEST_ASSERT_GREATER_THAN(0u, param->signatures[i].length);
TEST_ASSERT_LESS_OR_EQUAL(TEST_SIGN_SIGNATURE_LENGTH, param->signatures[i].length);
TEST_ASSERT_NOT_EQUAL(param->signatures[i].length,
CountZero(param->signatures[i].val, param->signatures[i].length));
}
// 5. export the public key which is imported in the third step
RUN_AND_PRINT_ELAPSED_TIME(res, loader->exportPublicKey(&param->anotherKeyAlias, &param->anotherOutPk));
TEST_ASSERT_EQUAL(HAL_SUCCESS, res);
// 6. verify the signature that is signed in the fourth step with the public key that is imported in the fifth step
TestExportImportSignVerifyInnerVerfiyNormalAndAbnormalCases(loader, alg, param);
// 7. compare the public keys which are exported in the second and fifth step
PrintBuffer("exported public key", param->outPubKey.val, param->outPubKey.length);
TEST_ASSERT_GREATER_THAN(0u, param->outPubKey.length);
TEST_ASSERT_LESS_OR_EQUAL(TEST_EX_IM_SN_VF_OUT_PUB_KEY_LENGTH, param->outPubKey.length);
TEST_ASSERT_NOT_EQUAL(param->outPubKey.length, CountZero(param->outPubKey.val, param->outPubKey.length));
TEST_ASSERT_EQUAL_MESSAGE(param->outPubKey.length, param->anotherOutPk.length,
TEST_EXPORT_DIFFERENT_ERROR_MESSAGE);
TEST_ASSERT_EQUAL_HEX8_ARRAY_MESSAGE(param->outPubKey.val, param->anotherOutPk.val, param->outPubKey.length,
TEST_EXPORT_DIFFERENT_ERROR_MESSAGE);
if (loader->deleteKey) {
LOGD("test deleteKey");
// 8. delete the key pair which is generated in the first step
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&param->keyAlias));
// 9. delete the public key which is imported in the third step
TEST_ASSERT_EQUAL(HAL_SUCCESS, loader->deleteKey(&param->anotherKeyAlias));
}
}
static void TestExportImportSignVerifyReleaseResources(struct TestExportImportSignVerifyParam *param)
{
free(param->extInfo.authId.val);
param->extInfo.authId.val = NULL;
free(param->keyAlias.val);
param->keyAlias.val = NULL;
free(param->outPubKey.val);
param->outPubKey.val = NULL;
free(param->anotherKeyAlias.val);
param->anotherKeyAlias.val = NULL;
for (uint32_t i = 0; i < ARRAY_SIZE(TEST_SIGN_MSG_LENGTHES); ++i) {
free(param->messages[i].val);
param->messages[i].val = NULL;
free(param->signatures[i].val);
param->signatures[i].val = NULL;
}
free(param->anotherOutPk.val);
param->anotherOutPk.val = NULL;
}
static void TestExportImportSignVerify(const AlgLoader *loader, const Algorithm alg)
{
TEST_ASSERT_NOT_NULL(loader->generateKeyPairWithStorage);
// only two test cases for exportPublicKey, P256 and ED25519, outKey length is 32
TEST_ASSERT_NOT_NULL(loader->exportPublicKey);
TEST_ASSERT_NOT_NULL(loader->importPublicKey);
// sign message length varies from min 1 to max 1024
TEST_ASSERT_NOT_NULL(loader->sign);
TEST_ASSERT_NOT_NULL(loader->verify);
TEST_ASSERT_TRUE((alg == ED25519) || (alg == P256));
if (((alg != ED25519) && (alg != P256)) || !loader->generateKeyPairWithStorage ||
!loader->exportPublicKey || !loader->importPublicKey || !loader->sign || !loader->verify) {
LOGE("one of requested pointer is NULL or alg is invalid, can not test!");
return;
}
struct TestExportImportSignVerifyParam param;
TestExportImportSignVerifyPrepareResources(&param);
TestExportImportSignVerifyInner(loader, alg, &param);
TestExportImportSignVerifyReleaseResources(&param);
}
static void TestExportImportSignVerifyP256AndEd25519(const AlgLoader *loader)
{
#if TEST_EXPORT_IMPORT_SIGN_VERIFY_ED25519
LOGI("test export import sign verify ED25519");
TestExportImportSignVerify(loader, ED25519);
#else // TEST_EXPORT_IMPORT_SIGN_VERIFY_ED25519
LOGE("no TEST_EXPORT_IMPORT_SIGN_VERIFY_ED25519, do not test ED25519");
#endif // TEST_EXPORT_IMPORT_SIGN_VERIFY_ED25519
#if TEST_EXPORT_IMPORT_SIGN_VERIFY_P256
LOGI("test export import sign verify P256");
TestExportImportSignVerify(loader, P256);
#else // TEST_EXPORT_IMPORT_SIGN_VERIFY_P256
LOGE("no TEST_EXPORT_IMPORT_SIGN_VERIFY_P256, do not test P256");
#endif // TEST_EXPORT_IMPORT_SIGN_VERIFY_P256
}
#endif // (TEST_EXPORT_PUBLIC_KEY || TEST_IMPORT_PUBLIC_KEY || TEST_ALGORITHM_SIGN || TEST_ALGORITHM_VERIFY)
static void TestExportPublicKey(const AlgLoader *loader)
#if TEST_EXPORT_PUBLIC_KEY
{
TEST_ASSERT_NOT_NULL(loader->exportPublicKey);
if (!loader->exportPublicKey) {
LOGE("exportPublicKey pointer is NULL, can not test!");
return;
}
TestExportImportSignVerifyP256AndEd25519(loader);
}
#else // TEST_EXPORT_PUBLIC_KEY
{
TEST_ASSERT_NULL(loader->exportPublicKey);
LOGE("no TEST_EXPORT_PUBLIC_KEY, do not test exportPublicKey");
}
#endif // TEST_EXPORT_PUBLIC_KEY
static void TestSign(const AlgLoader *loader)
#if TEST_ALGORITHM_SIGN
{
TEST_ASSERT_NOT_NULL(loader->sign);
if (!loader->sign) {
LOGE("sign pointer is NULL, can not test!");
return;
}
TestExportImportSignVerifyP256AndEd25519(loader);
}
#else // TEST_ALGORITHM_SIGN
{
TEST_ASSERT_NULL(loader->sign);
LOGE("no TEST_ALGORITHM_SIGN, do not test sign");
}
#endif // TEST_ALGORITHM_SIGN
static void TestVerify(const AlgLoader *loader)
#if TEST_ALGORITHM_VERIFY
{
TEST_ASSERT_NOT_NULL(loader->verify);
if (!loader->verify) {
LOGE("verify pointer is NULL, can not test!");
return;
}
TestExportImportSignVerifyP256AndEd25519(loader);
}
#else // TEST_ALGORITHM_VERIFY
{
TEST_ASSERT_NULL(loader->verify);
LOGE("no TEST_ALGORITHM_VERIFY, do not test verify");
}
#endif // TEST_ALGORITHM_VERIFY
static void TestImportPublicKey(const AlgLoader *loader)
#if TEST_IMPORT_PUBLIC_KEY
{
TEST_ASSERT_NOT_NULL(loader->importPublicKey);
if (!loader->importPublicKey) {
LOGE("importPublicKey pointer is NULL, can not test!");
return;
}
TestExportImportSignVerifyP256AndEd25519(loader);
}
#else // TEST_IMPORT_PUBLIC_KEY
{
TEST_ASSERT_NULL(loader->importPublicKey);
LOGE("no TEST_IMPORT_PUBLIC_KEY, do not test importPublicKey");
}
#endif // TEST_IMPORT_PUBLIC_KEY
#if TEST_CHECK_DL_PUBLIC_KEY // {
static void TestCheckDlPublicKeyInner(const AlgLoader *loader,
Uint8Buff *key, const char *primeHex)
{
bool res;
int randIndex;
// 1. all zero
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(false, res);
// 2. value is 1
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
key->val[key->length - 1] = TEST_CHECK_DL_VALUE_ONE;
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(false, res);
// 3. value is 2
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
key->val[key->length - 1] = TEST_CHECK_DL_VALUE_TWO;
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(true, res);
// 4. value is between 2 and primeHex - 2
// first, init value with 2
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
key->val[key->length - 1] = TEST_CHECK_DL_VALUE_TWO;
// then add 1 on rand byte
randIndex = rand() % key->length;
key->val[randIndex] += TEST_CHECK_DL_VALUE_ONE;
PrintBuffer("rand key", key->val, key->length);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(true, res);
// first, init value with primeHex - 2
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
TEST_ASSERT_EQUAL(HAL_SUCCESS, HexStringToByte(primeHex, key->val, key->length));
TEST_ASSERT_GREATER_OR_EQUAL(TEST_CHECK_DL_VALUE_TWO, key->val[key->length - 1]);
key->val[key->length - 1] -= TEST_CHECK_DL_VALUE_TWO;
// then sub 1 on rand byte
do {
randIndex = rand() % key->length;
} while (key->val[randIndex] < TEST_CHECK_DL_VALUE_ONE);
key->val[randIndex] -= TEST_CHECK_DL_VALUE_ONE;
PrintBuffer("rand key", key->val, key->length);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(true, res);
// 5. value is primeHex - 2
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
TEST_ASSERT_EQUAL(HAL_SUCCESS, HexStringToByte(primeHex, key->val, key->length));
TEST_ASSERT_GREATER_OR_EQUAL(TEST_CHECK_DL_VALUE_TWO, key->val[key->length - 1]);
key->val[key->length - 1] -= TEST_CHECK_DL_VALUE_TWO;
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(true, res);
// 6. value is primeHex - 1
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
TEST_ASSERT_EQUAL(HAL_SUCCESS, HexStringToByte(primeHex, key->val, key->length));
TEST_ASSERT_GREATER_OR_EQUAL(TEST_CHECK_DL_VALUE_ONE, key->val[key->length - 1]);
key->val[key->length - 1] -= TEST_CHECK_DL_VALUE_ONE;
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(false, res);
// 7. value is primeHex
TEST_ASSERT_EQUAL(EOK, memset_s(key->val, key->length, 0, key->length));
TEST_ASSERT_EQUAL(HAL_SUCCESS, HexStringToByte(primeHex, key->val, key->length));
RUN_AND_PRINT_ELAPSED_TIME(res, loader->checkDlPublicKey(key, primeHex));
TEST_ASSERT_EQUAL(false, res);
}
static void TestCheckDlPublicKey(const AlgLoader *loader)
{
TEST_ASSERT_NOT_NULL(loader->checkDlPublicKey);
if (!loader->checkDlPublicKey) {
LOGE("checkDlPublicKey pointer is NULL, can not test!");
return;
}
Uint8Buff key;
key.length = PAKE_DL_PRIME_LEN_256;
key.val = (uint8_t *)malloc(key.length);
TEST_ASSERT_NOT_NULL(key.val);
TestCheckDlPublicKeyInner(loader, &key, LARGE_PRIME_NUM_HEX_256);
free(key.val);
key.length = PAKE_DL_PRIME_LEN_384;
key.val = (uint8_t *)malloc(key.length);
TEST_ASSERT_NOT_NULL(key.val);
TestCheckDlPublicKeyInner(loader, &key, LARGE_PRIME_NUM_HEX_384);
free(key.val);
}
#else // TEST_CHECK_DL_PUBLIC_KEY // } {
static void TestCheckDlPublicKey(const AlgLoader *loader)
{
TEST_ASSERT_NULL(loader->checkDlPublicKey);
LOGE("no TEST_CHECK_DL_PUBLIC_KEY, do not test checkDlPublicKey");
}
#endif // TEST_CHECK_DL_PUBLIC_KEY // }
static void TestCheckEcPublicKey(const AlgLoader *loader)
{
TEST_ASSERT_NULL(loader->checkEcPublicKey);
LOGE("loader->checkEcPublicKey is NULL, and nobody use it, do not test!");
}
#if TEST_BIG_NUM_COMPARE // {
static void TestBigNumCompareInnerMinMax(const AlgLoader *loader,
Uint8Buff *x, Uint8Buff *y)
{
// 0. 0xFFFFFF > 0x000000
int res;
TEST_ASSERT_EQUAL(EOK, memset_s(x->val, x->length, UINT8_MAX, x->length));
TEST_ASSERT_EQUAL(EOK, memset_s(y->val, y->length, 0, y->length));
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(1, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(-1, res);
}
static void TestBigNumCompareInnerFull(const AlgLoader *loader,
Uint8Buff *x, Uint8Buff *y)
{
int previous, res;
// 1. 0x123456 > 0x123455
TEST_ASSERT_EQUAL(EOK, memcpy_s(x->val, x->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val, y->val, TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL);
previous = y->val[y->length - 1];
y->val[y->length - 1] -= 1;
TEST_ASSERT_LESS_THAN(previous, y->val[y->length - 1]);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(1, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(-1, res);
// 2. 0x123456 = 0x123456
TEST_ASSERT_EQUAL(EOK, memcpy_s(x->val, x->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val, y->val, TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(0, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(0, res);
// 3. 0x123456 < 0x123457
TEST_ASSERT_EQUAL(EOK, memcpy_s(x->val, x->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val, y->val, TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL);
previous = y->val[y->length - 1];
y->val[y->length - 1] += 1;
TEST_ASSERT_GREATER_THAN(previous, y->val[y->length - 1]);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(-1, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(1, res);
}
static void TestBigNumCompareInnerHalf(const AlgLoader *loader,
Uint8Buff *x, Uint8Buff *y)
{
int previous, res;
// 4. 0x003456 > 0x3455
TEST_ASSERT_EQUAL(EOK,
memset_s(x->val, x->length, 0, TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF));
TEST_ASSERT_EQUAL(EOK, memcpy_s(
x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, x->length - TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, y->val,
TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF);
previous = y->val[y->length - 1];
y->val[y->length - 1] -= 1;
TEST_ASSERT_LESS_THAN(previous, y->val[y->length - 1]);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(1, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(-1, res);
// 5. 0x003456 = 0x3456
TEST_ASSERT_EQUAL(EOK,
memset_s(x->val, x->length, 0, TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF));
TEST_ASSERT_EQUAL(EOK, memcpy_s(
x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, x->length - TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, y->val,
TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(0, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(0, res);
// 6. 0x003456 < 0x3457
TEST_ASSERT_EQUAL(EOK,
memset_s(x->val, x->length, 0, TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF));
TEST_ASSERT_EQUAL(EOK, memcpy_s(
x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, x->length - TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, y->val,
TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF);
previous = y->val[y->length - 1];
y->val[y->length - 1] += 1;
TEST_ASSERT_GREATER_THAN(previous, y->val[y->length - 1]);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(-1, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(1, res);
}
static void TestBigNumCompareInnerCompareFullAgainstHalf(const AlgLoader *loader,
Uint8Buff *x, Uint8Buff *y)
{
int res;
// 7. 0x123456 > 0x3456
TEST_ASSERT_EQUAL(EOK, memcpy_s(
x->val, x->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(
x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, x->length - TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL(EOK, memcpy_s(y->val, y->length,
TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF, sizeof(TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF)));
TEST_ASSERT_EQUAL_HEX8_ARRAY(x->val + TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF, y->val,
TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(x, y));
TEST_ASSERT_EQUAL(1, res);
RUN_AND_PRINT_ELAPSED_TIME(res, loader->bigNumCompare(y, x));
TEST_ASSERT_EQUAL(-1, res);
}
static void TestBigNumCompare(const AlgLoader *loader)
{
TEST_ASSERT_NOT_NULL(loader->bigNumCompare);
if (!loader->bigNumCompare) {
LOGE("bigNumCompare pointer is NULL, can not test!");
return;
}
Uint8Buff x = { (uint8_t *)malloc(TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL), TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL };
TEST_ASSERT_NOT_NULL(x.val);
Uint8Buff y = { (uint8_t *)malloc(TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL), TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL };
TEST_ASSERT_NOT_NULL(y.val);
TestBigNumCompareInnerMinMax(loader, &x, &y);
TestBigNumCompareInnerFull(loader, &x, &y);
free(y.val);
y.length = TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF;
y.val = (uint8_t *)malloc(y.length);
TEST_ASSERT_NOT_NULL(y.val);
TestBigNumCompareInnerHalf(loader, &x, &y);
TestBigNumCompareInnerCompareFullAgainstHalf(loader, &x, &y);
free(x.val);
free(y.val);
}
#else // TEST_BIG_NUM_COMPARE // } {
static void TestBigNumCompare(const AlgLoader *loader)
{
TEST_ASSERT_NULL(loader->bigNumCompare);
LOGE("no TEST_BIG_NUM_COMPARE, do not test loader->bigNumCompare");
}
#endif // TEST_BIG_NUM_COMPARE // {
void TestHcAlg(void)
{
const AlgLoader *loader = GetLoaderInstance();
......@@ -993,7 +1611,11 @@ void TestHcAlg(void)
TestComputeHkdf(loader);
TestImportAsymmetricKey(loader);
#if (defined(DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY) && DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY)
(void)(TestImportSymmetricKey);
#else // DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY
TestImportSymmetricKey(loader);
#endif // DO_NOT_TEST_DEPRECATED_IMPORT_SYMMETRIC_KEY
TestCheckKeyExist(loader);
......@@ -1012,6 +1634,22 @@ void TestHcAlg(void)
TestAgreeSharedSecret(loader);
TestBigNumExpMod(loader);
TestGenerateKeyPair(loader);
TestExportPublicKey(loader);
TestSign(loader);
TestVerify(loader);
TestImportPublicKey(loader);
TestCheckDlPublicKey(loader);
TestCheckEcPublicKey(loader);
TestBigNumCompare(loader);
}
#ifdef __cplusplus
......
......@@ -372,9 +372,9 @@ enum {
HKDF_PAKE_SHAREDSECRET_DERIVE_UNIONKEY_SALT_LEN = 16,
HKDF_PAKE_SHAREDSECRET_DERIVE_UNIONKEY_OUTKEY_LEN = 48,
IMPORT_ASYMMETRIC_KEY_KEYALIAS_LEN_MAX = 32,
IMPORT_ASYMMETRIC_KEY_KEYALIAS_LEN_MIN = 1,
IMPORT_ASYMMETRIC_KEY_AUTHTOKEN_LEN = 32,
IMPORT_SYMMETRIC_KEY_KEYALIAS_LEN_MAX = 32,
IMPORT_SYMMETRIC_KEY_KEYALIAS_LEN_MIN = 1,
IMPORT_SYMMETRIC_KEY_AUTHTOKEN_LEN = 32,
};
enum {
......@@ -623,14 +623,103 @@ enum {
};
enum {
TEST_IMPORT_ASYMMETRIC_KEY_AUTH_ID_LENGTH_32 = 32,
TEST_IMPORT_ASYMMETRIC_KEY_AUTH_ID_LENGTH_64 = 64,
TEST_IMPORT_SYMMETRIC_KEY_AUTH_ID_LENGTH_32 = 32,
TEST_IMPORT_SYMMETRIC_KEY_AUTH_ID_LENGTH_64 = 64,
};
enum {
TEST_GENERATE_KEY_PAIR_WITH_STORAGE_AUTH_ID_LENGTH = 32,
};
// TestExportImportSignVerify
enum {
TEST_EX_IM_SN_VF_EXTRA_INFO_AUTH_ID_LENGTH = 32,
TEST_EX_IM_SN_VF_KEY_ALIAS_LENGTH = 64,
TEST_EX_IM_SN_VF_KEY_LENGTH = 32,
TEST_EX_IM_SN_VF_OUT_PUB_KEY_LENGTH = 32,
TEST_SIGN_MESSAGE_LENGTH_1 = 1,
TEST_SIGN_MESSAGE_LENGTH_2 = 2,
TEST_SIGN_MESSAGE_LENGTH_4 = 4,
TEST_SIGN_MESSAGE_LENGTH_8 = 8,
TEST_SIGN_MESSAGE_LENGTH_16 = 16,
TEST_SIGN_MESSAGE_LENGTH_32 = 32,
TEST_SIGN_MESSAGE_LENGTH_64 = 64,
TEST_SIGN_MESSAGE_LENGTH_128 = 128,
TEST_SIGN_MESSAGE_LENGTH_256 = 256,
TEST_SIGN_MESSAGE_LENGTH_512 = 512,
TEST_SIGN_MESSAGE_LENGTH_1024 = 1024,
TEST_SIGN_SIGNATURE_LENGTH = 64,
};
static const uint32_t TEST_SIGN_MSG_LENGTHES[] = {
TEST_SIGN_MESSAGE_LENGTH_1,
TEST_SIGN_MESSAGE_LENGTH_2,
TEST_SIGN_MESSAGE_LENGTH_4,
TEST_SIGN_MESSAGE_LENGTH_8,
TEST_SIGN_MESSAGE_LENGTH_16,
TEST_SIGN_MESSAGE_LENGTH_32,
TEST_SIGN_MESSAGE_LENGTH_64,
TEST_SIGN_MESSAGE_LENGTH_128,
TEST_SIGN_MESSAGE_LENGTH_256,
TEST_SIGN_MESSAGE_LENGTH_512,
TEST_SIGN_MESSAGE_LENGTH_1024,
};
static const char TEST_EXPORT_DIFFERENT_ERROR_MESSAGE[] = "two different public keys are exported";
// g_largePrimeNumberHex384 and g_largePrimeNumberHex256 are from
// base/security/deviceauth/services/protocol/src/pake_protocol/pake_protocol_dl_common/pake_protocol_dl_common.c
static const char LARGE_PRIME_NUM_HEX_384[] =
"FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E088A67CC74"
"020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B302B0A6DF25F1437"
"4FE1356D6D51C245E485B576625E7EC6F44C42E9A637ED6B0BFF5CB6F406B7ED"
"EE386BFB5A899FA5AE9F24117C4B1FE649286651ECE45B3DC2007CB8A163BF05"
"98DA48361C55D39A69163FA8FD24CF5F83655D23DCA3AD961C62F356208552BB"
"9ED529077096966D670C354E4ABC9804F1746C08CA18217C32905E462E36CE3B"
"E39E772C180E86039B2783A2EC07A28FB5C55DF06F4C52C9DE2BCBF695581718"
"3995497CEA956AE515D2261898FA051015728E5A8AAAC42DAD33170D04507A33"
"A85521ABDF1CBA64ECFB850458DBEF0A8AEA71575D060C7DB3970F85A6E1E4C7"
"ABF5AE8CDB0933D71E8C94E04A25619DCEE3D2261AD2EE6BF12FFA06D98A0864"
"D87602733EC86A64521F2B18177B200CBBE117577A615D6C770988C0BAD946E2"
"08E24FA074E5AB3143DB5BFCE0FD108E4B82D120A93AD2CAFFFFFFFFFFFFFFFF";
static const char LARGE_PRIME_NUM_HEX_256[] =
"FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E088A67CC74"
"020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B302B0A6DF25F1437"
"4FE1356D6D51C245E485B576625E7EC6F44C42E9A637ED6B0BFF5CB6F406B7ED"
"EE386BFB5A899FA5AE9F24117C4B1FE649286651ECE45B3DC2007CB8A163BF05"
"98DA48361C55D39A69163FA8FD24CF5F83655D23DCA3AD961C62F356208552BB"
"9ED529077096966D670C354E4ABC9804F1746C08CA18217C32905E462E36CE3B"
"E39E772C180E86039B2783A2EC07A28FB5C55DF06F4C52C9DE2BCBF695581718"
"3995497CEA956AE515D2261898FA051015728E5A8AACAA68FFFFFFFFFFFFFFFF";
enum {
PAKE_DL_PRIME_LEN_256 = 256,
PAKE_DL_PRIME_LEN_384 = 384,
};
enum {
TEST_CHECK_DL_VALUE_ONE = 1,
TEST_CHECK_DL_VALUE_TWO = 2,
};
enum {
TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL = 32,
TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF = TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL / 2, // 16
};
static const uint8_t TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_FULL[TEST_BIG_NUM_COMPARE_NUM_LENGTH_FULL] = {
/* */ /* */
0xab, 0xcd, 0xef, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0x01, 0x23, 0x45, 0x67, 0x89,
0xab, 0xcd, 0xef, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0x01, 0x23, 0x45, 0x67, 0x89,
};
static const uint8_t TEST_BIG_NUM_COMPARE_NUM_EXAMPLE_HALF[TEST_BIG_NUM_COMPARE_NUM_LENGTH_HALF] = {
/* */ /* */
0xab, 0xcd, 0xef, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0x01, 0x23, 0x45, 0x67, 0x89,
};
#ifdef __cplusplus
}
#endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册