1 /*
2  * Copyright (c) 2022 Nordic Semiconductor ASA
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #include "mocks/aes.h"
8 #include "mocks/aes_expects.h"
9 
10 #include <zephyr/bluetooth/crypto.h>
11 #include <zephyr/fff.h>
12 #include <zephyr/kernel.h>
13 
14 #include <host/crypto.h>
15 
16 DEFINE_FFF_GLOBALS;
17 
fff_reset_rule_before(const struct ztest_unit_test * test,void * fixture)18 static void fff_reset_rule_before(const struct ztest_unit_test *test, void *fixture)
19 {
20 	AES_FFF_FAKES_LIST(RESET_FAKE);
21 }
22 
23 ZTEST_RULE(fff_reset_rule, fff_reset_rule_before, NULL);
24 
25 ZTEST_SUITE(bt_encrypt_le, NULL, NULL, NULL, NULL, NULL);
26 
27 /*
28  *  Test bt_encrypt_le() succeeds
29  *
30  *  Constraints:
31  *   - tc_aes128_set_encrypt_key() succeeds and returns 'TC_CRYPTO_SUCCESS'.
32  *   - tc_aes_encrypt() succeeds and returns 'TC_CRYPTO_SUCCESS'.
33  *
34  *  Expected behaviour:
35  *   - bt_encrypt_le() returns 0 (success)
36  */
ZTEST(bt_encrypt_le,test_bt_encrypt_le_succeeds)37 ZTEST(bt_encrypt_le, test_bt_encrypt_le_succeeds)
38 {
39 	int err;
40 	const uint8_t key[16] = {0};
41 	const uint8_t plaintext[16] = {0};
42 	uint8_t enc_data[16] = {0};
43 
44 	psa_import_key_fake.return_val = PSA_SUCCESS;
45 	psa_cipher_encrypt_fake.return_val = PSA_SUCCESS;
46 
47 	err = bt_encrypt_le(key, plaintext, enc_data);
48 
49 	expect_single_call_psa_cipher_encrypt(enc_data);
50 
51 	zassert_ok(err, "Unexpected error code '%d' was returned", err);
52 }
53