1 /* 2 * Copyright (c) 2022 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 #ifndef HUKS_CIPHER_AES_TEST_COMMON_H 17 #define HUKS_CIPHER_AES_TEST_COMMON_H 18 19 #include <string> 20 #include "huks_three_stage_test_common.h" 21 22 namespace Unittest::AesCipher 23 { 24 static const uint32_t AES_COMMON_SIZE = 1024; 25 static const uint32_t IV_SIZE = 16; 26 static const uint32_t AAD_SIZE = 16; 27 static const uint32_t NONCE_SIZE = 12; 28 static const uint32_t AEAD_SIZE = 16; 29 30 static uint8_t IV[IV_SIZE] = {0}; 31 static uint8_t AAD[AAD_SIZE] = {0}; 32 static uint8_t NONCE[NONCE_SIZE] = {0}; 33 static uint8_t AEAD[AEAD_SIZE] = {0}; 34 35 static const std::string g_inData = "Hks_AES_Cipher_Test_000000000000000000000000000000000000000000000000000000000000" 36 "00000000000000000000000000000000000000000000000000000000000000000000000000000000" 37 "0000000000000000000000000000000000000000000000000000000000000000000000000_string"; 38 39 OH_Huks_Result HksAesCipherTestEncrypt( 40 const struct OH_Huks_Blob *keyAlias, 41 const struct OH_Huks_ParamSet *encryptParamSet, 42 const struct OH_Huks_Blob *inData, 43 struct OH_Huks_Blob *cipherText); 44 45 OH_Huks_Result HksAesCipherTestDecrypt( 46 const struct OH_Huks_Blob *keyAlias, 47 const struct OH_Huks_ParamSet *decryptParamSet, 48 const struct OH_Huks_Blob *cipherText, 49 struct OH_Huks_Blob *plainText, const struct OH_Huks_Blob *inData); 50 51 OH_Huks_Result HksAesCipherTestCaseOther( 52 const struct OH_Huks_Blob *keyAlias, 53 struct OH_Huks_ParamSet *genParamSet, 54 struct OH_Huks_ParamSet *encryptParamSet, 55 struct OH_Huks_ParamSet *decryptParamSet); 56 57 OH_Huks_Result HksAesCipherTestCaseGcm2( 58 const struct OH_Huks_Blob *keyAlias, 59 struct OH_Huks_ParamSet *genParamSet, 60 struct OH_Huks_ParamSet *encryptParamSet, 61 struct OH_Huks_ParamSet *decryptParamSet, struct OH_Huks_ParamSet *decrypt1ParamSet); 62 } // namespace Unittest::AesCipher 63 #endif // HUKS_CIPHER_AES_TEST_COMMON_H 64