• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Copyright (c) 2025 Huawei Device Co., Ltd.
2# Licensed under the Apache License, Version 2.0 (the "License");
3# you may not use this file except in compliance with the License.
4# You may obtain a copy of the License at
5#
6#     http://www.apache.org/licenses/LICENSE-2.0
7#
8# Unless required by applicable law or agreed to in writing, software
9# distributed under the License is distributed on an "AS IS" BASIS,
10# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11# See the License for the specific language governing permissions and
12# limitations under the License.
13
14import("//base/security/device_auth/deps_adapter/deviceauth_hals.gni")
15import("//base/security/device_auth/services/deviceauth.gni")
16import("../../unittest/tdd_framework/tdd_framework.gni")
17
18#####################hydra-fuzz###################
19import("//build/config/features.gni")
20import("//build/ohos.gni")
21import("//build/test.gni")
22module_output_path = "device_auth/device_auth"
23
24##############################fuzztest##########################################
25ohos_fuzztest("CommonLibFuzzTest") {
26  module_out_path = module_output_path
27  fuzz_config_file = "${deviceauth_path}/test/fuzztest/commonlib_fuzzer"
28
29  include_dirs = inc_path
30  include_dirs += hals_inc_path
31
32  include_dirs += [
33    ".",
34    "./include",
35    "../../unittest/deviceauth/include",
36    "${dev_frameworks_path}/inc/permission_adapter",
37    "${dev_frameworks_path}/inc/hiview_adapter",
38  ]
39  include_dirs += identity_manager_inc
40
41  sources = hal_common_files
42  sources -= [ "${common_lib_path}/impl/src/hc_parcel.c" ]
43  sources += [
44    "${key_management_adapter_path}/impl/src/common/mbedtls_ec_adapter.c",
45    "${key_management_adapter_path}/impl/src/huks_adapter.c",
46    "${key_management_adapter_path}/impl/src/huks_adapter_utils.c",
47    "${key_management_adapter_path}/impl/src/standard/crypto_hash_to_point.c",
48    "${key_management_adapter_path}/impl/src/standard/huks_adapter_diff_impl.c",
49    "${os_adapter_path}/impl/src/hc_log.c",
50    "${os_adapter_path}/impl/src/linux/hc_condition.c",
51    "${os_adapter_path}/impl/src/linux/hc_file.c",
52    "${os_adapter_path}/impl/src/linux/hc_init_protection.c",
53    "${os_adapter_path}/impl/src/linux/hc_thread.c",
54    "${os_adapter_path}/impl/src/linux/hc_types.c",
55    "../../unittest/deviceauth/source/hc_dev_info_mock.c",
56  ]
57  sources += [ "commonlib_fuzzer.cpp" ]
58  sources += identity_manager_files
59  sources += identity_service_mock_files
60  sources += dev_frameworks_files
61  sources += deviceauth_common_files
62  sources += sa_load_on_demand_mock_files
63  sources += group_database_manager_files
64  sources += ext_plugin_manager_files
65  sources += session_manager_files
66  sources += session_v1_files
67  sources += session_v2_files
68  sources += iso_protocol_files
69  sources += ec_speke_protocol_files
70  sources += auth_code_import_files
71  sources += pub_key_exchange_files
72  sources += save_trusted_info_files
73  sources += creds_manager_files
74  sources += broadcast_manager_files
75  sources += soft_bus_channel_mock_files
76
77  sources += group_auth_files
78  sources += group_auth_account_unrelated_files
79
80  sources += group_manager_files
81  sources += group_manager_peer_to_peer_files
82
83  sources += authenticators_p2p_files
84  sources += authenticators_p2p_iso_files
85  sources += authenticators_p2p_pake_files
86  sources += authenticators_standard_exchange_task_files
87
88  sources += account_related_files
89
90  sources += privacy_enhancement_files
91  sources += mk_agree_files
92
93  sources += security_label_adapter_files
94
95  sources -= [
96    "${authenticators_path}/src/account_unrelated/iso_task/iso_task_main.c",
97    "${authenticators_path}/src/account_unrelated/pake_task/pake_v1_task/pake_v1_task_main.c",
98  ]
99
100  sources += [
101    "${dev_frameworks_path}/src/account_task_manager_mock/account_task_manager_mock.c",
102    "${dev_frameworks_path}/src/plugin_adapter_mock/account_auth_plugin_proxy_mock.c",
103    "../../unittest/deviceauth/source/os_account_adapter_mock.c",
104    "../../unittest/deviceauth/source/protocol_task_main_mock.c",
105  ]
106
107  defines = [
108    "P2P_PAKE_DL_PRIME_LEN_384",
109    "P2P_PAKE_EC_TYPE",
110    "ENABLE_EC_SPEKE",
111    "ENABLE_ISO",
112    "ENABLE_AUTH_CODE_IMPORT",
113    "ENABLE_PUB_KEY_EXCHANGE",
114    "ENABLE_SAVE_TRUSTED_INFO",
115    "ENABLE_PSEUDONYM",
116    "DEV_AUTH_FUNC_TEST",
117  ]
118
119  cflags = [ "-DHILOG_ENABLE" ]
120  cflags += [
121    "-DDEV_AUTH_WORK_THREAD_STACK_SIZE=${device_auth_hichain_thread_stack_size}",
122    "-DMAX_AUTH_SESSION_COUNT=${max_auth_session_count}",
123  ]
124
125  external_deps = [
126    "access_token:libaccesstoken_sdk",
127    "cJSON:cjson",
128    "c_utils:utils",
129    "hilog:libhilog",
130    "huks:libhukssdk",
131    "mbedtls:mbedtls_shared",
132    "openssl:libcrypto_static",
133  ]
134}
135
136###############################################################################
137group("fuzztest") {
138  testonly = true
139  deps = []
140  deps += [
141    # deps file
142    ":CommonLibFuzzTest",
143  ]
144}
145###############################################################################
146