• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Copyright (c) 2024 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")
16
17#####################hydra-fuzz###################
18import("//build/config/features.gni")
19import("//build/ohos.gni")
20import("//build/test.gni")
21module_output_path = "device_auth/device_auth"
22
23##############################fuzztest##########################################
24ohos_fuzztest("DevAuthFuncFuzzTest") {
25  module_out_path = module_output_path
26  fuzz_config_file = "${deviceauth_path}/test/fuzztest/devauthfunc_fuzzer"
27  include_dirs = inc_path
28  include_dirs += hals_inc_path
29
30  include_dirs += [
31    ".",
32    "../../unittest/deviceauth/include",
33    "../../unittest/deviceauth/unit_test/include",
34    "${dev_frameworks_path}/inc/permission_adapter",
35    "${dev_frameworks_path}/inc/hiview_adapter",
36  ]
37
38  sources = hal_common_files
39  sources -= [ "${common_lib_path}/impl/src/json_utils.c" ]
40  sources += [
41    "${key_management_adapter_path}/impl/src/common/mbedtls_ec_adapter.c",
42    "${key_management_adapter_path}/impl/src/huks_adapter.c",
43    "${key_management_adapter_path}/impl/src/huks_adapter_utils.c",
44    "${key_management_adapter_path}/impl/src/standard/crypto_hash_to_point.c",
45    "${key_management_adapter_path}/impl/src/standard/huks_adapter_diff_impl.c",
46    "${os_adapter_path}/impl/src/hc_log.c",
47    "${os_adapter_path}/impl/src/linux/hc_condition.c",
48    "${os_adapter_path}/impl/src/linux/hc_file.c",
49    "${os_adapter_path}/impl/src/linux/hc_init_protection.c",
50    "${os_adapter_path}/impl/src/linux/hc_thread.c",
51    "${os_adapter_path}/impl/src/linux/hc_types.c",
52    "../../unittest/deviceauth/source/hc_dev_info_mock.c",
53    "../../unittest/deviceauth/source/json_utils_mock.c",
54  ]
55
56  sources += dev_frameworks_files
57  sources += deviceauth_common_files
58  sources += sa_load_on_demand_mock_files
59  sources += identity_service_mock_files
60  sources += group_database_manager_files
61  sources += ext_plugin_manager_files
62  sources += session_manager_files
63  sources += session_mini_files
64  sources += session_v1_files
65  sources += session_v2_files
66  sources += iso_protocol_files
67  sources += ec_speke_protocol_files
68  sources += auth_code_import_files
69  sources += pub_key_exchange_files
70  sources += save_trusted_info_files
71  sources += creds_manager_files
72  sources += broadcast_manager_files
73  sources += soft_bus_channel_mock_files
74
75  sources += group_auth_files
76  sources += group_auth_account_unrelated_files
77
78  sources += group_manager_files
79  sources += group_manager_peer_to_peer_files
80
81  sources += authenticators_p2p_files
82  sources += authenticators_p2p_iso_files
83  sources += authenticators_p2p_pake_files
84  sources += authenticators_standard_exchange_task_files
85
86  sources += account_related_files
87
88  sources += privacy_enhancement_files
89  sources += mk_agree_files
90
91  sources += security_label_adapter_files
92
93  sources -= [
94    "${authenticators_path}/src/account_unrelated/iso_task/iso_task_main.c",
95    "${authenticators_path}/src/account_unrelated/pake_task/pake_v1_task/pake_v1_task_main.c",
96  ]
97
98  sources += [
99    "${dev_frameworks_path}/src/account_task_manager_mock/account_task_manager_mock.c",
100    "${dev_frameworks_path}/src/plugin_adapter_mock/account_auth_plugin_proxy_mock.c",
101    "../../unittest/deviceauth/source/device_auth_ext_mock.c",
102    "../../unittest/deviceauth/source/os_account_adapter_mock.c",
103    "../../unittest/deviceauth/source/protocol_task_main_mock.c",
104  ]
105  defines = [
106    "P2P_PAKE_DL_PRIME_LEN_384",
107    "P2P_PAKE_EC_TYPE",
108    "ENABLE_EC_SPEKE",
109    "ENABLE_ISO",
110    "ENABLE_AUTH_CODE_IMPORT",
111    "ENABLE_PUB_KEY_EXCHANGE",
112    "ENABLE_SAVE_TRUSTED_INFO",
113    "ENABLE_ACCOUNT_AUTH_ISO",
114    "ENABLE_ACCOUNT_AUTH_EC_SPEKE",
115    "ENABLE_P2P_BIND_ISO",
116    "ENABLE_P2P_BIND_EC_SPEKE",
117    "ENABLE_P2P_AUTH_ISO",
118    "ENABLE_P2P_AUTH_EC_SPEKE",
119    "DEV_AUTH_FUNC_TEST",
120    "ENABLE_PSEUDONYM",
121  ]
122
123  sources += identity_manager_files
124  include_dirs += identity_manager_inc
125  sources += [ "devauthfunc_fuzzer.cpp" ]
126
127  cflags = [ "-DHILOG_ENABLE" ]
128  cflags += [
129    "-DDEV_AUTH_WORK_THREAD_STACK_SIZE=102400",
130    "-DMAX_AUTH_SESSION_COUNT=${max_auth_session_count}",
131  ]
132
133  external_deps = [
134    "cJSON:cjson",
135    "c_utils:utils",
136    "hilog:libhilog",
137    "huks:libhukssdk",
138    "mbedtls:mbedtls_shared",
139    "openssl:libcrypto_static",
140  ]
141}
142
143###############################################################################
144group("fuzztest") {
145  testonly = true
146  deps = []
147  deps += [
148    # deps file
149    ":DevAuthFuncFuzzTest",
150  ]
151}
152###############################################################################
153