代码解析 HWTEST_F(CryptoAesCipherTest, CryptoAesCipherTest094, TestSize.Level0) { int ret = 0; HcfSymKeyGenerator *generator = nullptr; HcfSymKey *key = nullptr; const char *generatorAlgoName = nullptr; const char *inputAlgoName = "AES128"; ret = HcfSymKeyGeneratorCreate(inputAlgoName, &generator); if (ret != 0) { LOGE("HcfSymKeyGeneratorCreate failed!%d", ret); goto CLEAR_UP; } ret = generator->generateSymKey(generator, &key); if (ret != 0) { LOGE("generateSymKey failed!"); goto CLEAR_UP; } // generator getAlgoName generatorAlgoName = generator->getAlgoName(reinterpret_cast<HcfSymKeyGenerator *>(key)); if (generatorAlgoName == nullptr) { LOGE("generator getAlgoName failed!"); ret = HCF_ERR_CRYPTO_OPERATION; } CLEAR_UP: HcfObjDestroy(key); HcfObjDestroy(generator); EXPECT_NE(ret, 0); }
时间: 2024-04-04 13:30:01 浏览: 59
HW_Dollar2_2.2.0.2104
这是一个 C++ 的测试函数,使用 Google Test 框架编写。该函数的名称是 CryptoAesCipherTest094,属于 CryptoAesCipherTest 类的测试用例之一,测试的级别是 Level0。该测试用例主要测试 HcfSymKeyGenerator 类的 generateSymKey 函数是否正常工作。
函数的主体部分首先声明了几个指针变量,分别为 HcfSymKeyGenerator 类型的 generator,HcfSymKey 类型的 key,以及两个 const char 类型的指针变量 generatorAlgoName 和 inputAlgoName。
接下来,调用 HcfSymKeyGeneratorCreate 函数创建 generator 对象,参数为 inputAlgoName,即算法名称为 AES128。如果创建失败,输出错误日志并跳转到 CLEAR_UP 标签处进行清理操作。然后,调用 generator 的 generateSymKey 函数生成对称密钥 key,如果生成失败,输出错误日志并跳转到 CLEAR_UP 标签处进行清理操作。
接着,调用 generator 的 getAlgoName 函数获取 generator 的算法名称,并将其存储在 generatorAlgoName 变量中。如果获取失败,输出错误日志并返回 HCF_ERR_CRYPTO_OPERATION 错误码。
最后,使用 HcfObjDestroy 函数销毁 key 和 generator 对象,并使用 EXPECT_NE 宏断言 ret 是否不等于 0,即测试结果是否为失败。
阅读全文