diff --git a/services/distributeddataservice/service/test/fuzztest/BUILD.gn b/services/distributeddataservice/service/test/fuzztest/BUILD.gn index 9e801a6adebfab38c8898add34d65fb1f4f5a629..b66239287c5ee29f32afec1a02784a4de82f07f9 100644 --- a/services/distributeddataservice/service/test/fuzztest/BUILD.gn +++ b/services/distributeddataservice/service/test/fuzztest/BUILD.gn @@ -31,6 +31,7 @@ group("fuzztest") { deps += [ "objectservicestub_fuzzer:fuzztest", "objectserviceimp_fuzzer:fuzztest", + "objectservicelistener_fuzzer:fuzztest", ] } diff --git a/services/distributeddataservice/service/test/fuzztest/objectserviceimp_fuzzer/objectserviceimp_fuzzer.cpp b/services/distributeddataservice/service/test/fuzztest/objectserviceimp_fuzzer/objectserviceimp_fuzzer.cpp index 857603cdfc170a4ed3f4b3527b9e9f7150372529..de7adc4e9bf1bd6d6327991e3af180e96e7e32f3 100644 --- a/services/distributeddataservice/service/test/fuzztest/objectserviceimp_fuzzer/objectserviceimp_fuzzer.cpp +++ b/services/distributeddataservice/service/test/fuzztest/objectserviceimp_fuzzer/objectserviceimp_fuzzer.cpp @@ -27,40 +27,21 @@ void ObjectStoreSaveFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); sptr callback; - std::string bundleName = provider.ConsumeRandomLengthString(); - std::string sessionId = provider.ConsumeRandomLengthString(); - std::string deviceId = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); + std::string sessionId = provider.ConsumeRandomLengthString(100); + std::string deviceId = provider.ConsumeRandomLengthString(100); std::map> data; std::vector remainingData = provider.ConsumeRemainingBytes(); data["key1"] = remainingData; objectServiceImpl->ObjectStoreSave(bundleName, sessionId, deviceId, data, callback); } -void SaveMetaDataFuzzTest(FuzzedDataProvider &provider) -{ - std::shared_ptr objectServiceImpl = std::make_shared(); - StoreMetaData saveMeta; - objectServiceImpl->SaveMetaData(saveMeta); - auto &dmAdapter = DeviceManagerAdapter::GetInstance(); - std::string uuid = provider.ConsumeRandomLengthString(); - std::string udid = provider.ConsumeRandomLengthString(); - if (uuid.empty()) { - uuid = "123"; - } - if (udid.empty()) { - udid = "234"; - } - dmAdapter.localInfo_.uuid = uuid; - dmAdapter.localInfo_.udid = udid; - objectServiceImpl->SaveMetaData(saveMeta); -} - void OnUserChangeFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); uint32_t code = static_cast(AccountStatus::DEVICE_ACCOUNT_SWITCHED); - std::string user = provider.ConsumeRandomLengthString(); - std::string account = provider.ConsumeRandomLengthString(); + std::string user = provider.ConsumeRandomLengthString(100); + std::string account = provider.ConsumeRandomLengthString(100); objectServiceImpl->OnUserChange(code, user, account); } @@ -68,8 +49,8 @@ void ObjectStoreRevokeSaveFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); sptr callback; - std::string bundleName = provider.ConsumeRandomLengthString(); - std::string sessionId = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); + std::string sessionId = provider.ConsumeRandomLengthString(100); objectServiceImpl->ObjectStoreRevokeSave(bundleName, sessionId, callback); } @@ -77,8 +58,8 @@ void ObjectStoreRetrieveFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); sptr callback; - std::string bundleName = provider.ConsumeRandomLengthString(); - std::string sessionId = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); + std::string sessionId = provider.ConsumeRandomLengthString(100); objectServiceImpl->ObjectStoreRetrieve(bundleName, sessionId, callback); } @@ -86,24 +67,27 @@ void RegisterDataObserverFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); sptr callback; - std::string bundleName = provider.ConsumeRandomLengthString(); - std::string sessionId = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); + std::string sessionId = provider.ConsumeRandomLengthString(100); objectServiceImpl->RegisterDataObserver(bundleName, sessionId, callback); } void OnAppUninstallFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); - std::string bundleName = provider.ConsumeRandomLengthString(); + if (objectServiceImpl->factory_.staticActs_ == nullptr) { + return; + } + std::string bundleName = provider.ConsumeRandomLengthString(100); int32_t user = provider.ConsumeIntegral(); int32_t index = provider.ConsumeIntegral(); - objectServiceImpl->OnAppUninstall(bundleName, user, index); + objectServiceImpl->factory_.staticActs_->OnAppUninstall(bundleName, user, index); } void ResolveAutoLaunchFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); - std::string identifier = provider.ConsumeRandomLengthString(); + std::string identifier = provider.ConsumeRandomLengthString(100); DistributedDB::AutoLaunchParam param; objectServiceImpl->ResolveAutoLaunch(identifier, param); } @@ -114,7 +98,7 @@ void OnAppExitFuzzTest(FuzzedDataProvider &provider) pid_t uid = provider.ConsumeIntegral(); pid_t pid = provider.ConsumeIntegral(); uint32_t tokenId = provider.ConsumeIntegral(); - std::string bundleName = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); objectServiceImpl->OnAppExit(uid, pid, tokenId, bundleName); objectServiceImpl->RegisterObjectServiceInfo(); objectServiceImpl->RegisterHandler(); @@ -124,14 +108,48 @@ void DumpObjectServiceInfoFuzzTest(FuzzedDataProvider &provider) { std::shared_ptr objectServiceImpl = std::make_shared(); int fd = provider.ConsumeIntegral(); - std::string key = provider.ConsumeRandomLengthString(); - std::string value1 = provider.ConsumeRandomLengthString(); - std::string value2 = provider.ConsumeRandomLengthString(); + std::string key = provider.ConsumeRandomLengthString(100); + std::string value1 = provider.ConsumeRandomLengthString(100); + std::string value2 = provider.ConsumeRandomLengthString(100); std::map> params; std::vector value = {value1, value2}; params.emplace(std::make_pair(key, value)); objectServiceImpl->DumpObjectServiceInfo(fd, params); } +void SaveMetaDataFuzzTest(FuzzedDataProvider &provider) +{ + std::shared_ptr objectServiceImpl = std::make_shared(); + StoreMetaData saveMeta; + objectServiceImpl->SaveMetaData(saveMeta); + auto &dmAdapter = DeviceManagerAdapter::GetInstance(); + std::string uuid = provider.ConsumeRandomLengthString(100); + std::string udid = provider.ConsumeRandomLengthString(100); + if (uuid.empty()) { + uuid = "123"; + } + if (udid.empty()) { + udid = "234"; + } + dmAdapter.localInfo_.uuid = uuid; + dmAdapter.localInfo_.udid = udid; + objectServiceImpl->SaveMetaData(saveMeta); +} + +void BindAssetStoreFuzzTest(FuzzedDataProvider &provider) +{ + std::shared_ptr objectServiceImpl = std::make_shared(); + std::string bundleName = provider.ConsumeRandomLengthString(100); + std::string sessionId = provider.ConsumeRandomLengthString(100); + ObjectStore::Asset asset = {.id = provider.ConsumeRandomLengthString(100), + .name = provider.ConsumeRandomLengthString(100), + .uri = provider.ConsumeRandomLengthString(100)}; + ObjectStore::AssetBindInfo bindInfo = {.storeName = provider.ConsumeRandomLengthString(100), + .tableName = provider.ConsumeRandomLengthString(100), + .primaryKey = {{"data1", 123}, {"data2", "test1"}}, + .field = provider.ConsumeRandomLengthString(100), + .assetName = provider.ConsumeRandomLengthString(100)}; + objectServiceImpl->BindAssetStore(bundleName, sessionId, asset, bindInfo); +} } // namespace OHOS /* Fuzzer entry point */ @@ -140,7 +158,6 @@ extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) FuzzedDataProvider provider(data, size); OHOS::ObjectStoreSaveFuzzTest(provider); OHOS::OnUserChangeFuzzTest(provider); - OHOS::SaveMetaDataFuzzTest(provider); OHOS::ObjectStoreRevokeSaveFuzzTest(provider); OHOS::ObjectStoreRetrieveFuzzTest(provider); OHOS::RegisterDataObserverFuzzTest(provider); @@ -148,5 +165,7 @@ extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) OHOS::ResolveAutoLaunchFuzzTest(provider); OHOS::OnAppExitFuzzTest(provider); OHOS::DumpObjectServiceInfoFuzzTest(provider); + OHOS::SaveMetaDataFuzzTest(provider); + OHOS::BindAssetStoreFuzzTest(provider); return 0; } \ No newline at end of file diff --git a/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/BUILD.gn b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..e2105e207fa3c9ba80c8493937162120d60e19c7 --- /dev/null +++ b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/BUILD.gn @@ -0,0 +1,64 @@ +# Copyright (c) 2025 Huawei Device Co., Ltd. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +##############################hydra-fuzz######################################## +import("//build/config/features.gni") +import("//build/test.gni") +import("//foundation/distributeddatamgr/datamgr_service/datamgr_service.gni") + +##############################fuzztest########################################## +ohos_fuzztest("ObjectServiceListenerFuzzTest") { + module_out_path = "datamgr_service/datamgr_service" + + include_dirs = [ + "${data_service_path}/service/object/include", + ] + + fuzz_config_file = + "${data_service_path}/service/test/fuzztest/objectservicelistener_fuzzer" + + cflags = [ + "-g", + "-O0", + "-Wno-unused-variable", + "-fno-omit-frame-pointer", + "-fno-access-control", + ] + + sources = [ + "objectservicelistener_fuzzer.cpp", + ] + + deps = [ + "${data_service_path}/framework:distributeddatasvcfwk", + "${data_service_path}/service:distributeddatasvc", + "${data_service_path}/service/object:distributeddata_object", + ] + + external_deps = [ + "access_token:libaccesstoken_sdk", + "access_token:libtokenid_sdk", + "data_object:data_object_inner", + "dfs_service:distributed_file_daemon_kit_inner", + "hilog:libhilog", + "ipc:ipc_single", + "kv_store:distributeddb", + ] +} + +############################################################################### +group("fuzztest") { + testonly = true + + deps = [ ":ObjectServiceListenerFuzzTest" ] +} +############################################################################### diff --git a/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/corpus/init b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/corpus/init new file mode 100644 index 0000000000000000000000000000000000000000..7ade8a0faafeaedba7241e7d4a97b8e1f9691932 --- /dev/null +++ b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/corpus/init @@ -0,0 +1,16 @@ +/* + * Copyright (c) 2025 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +FUZZ \ No newline at end of file diff --git a/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/objectservicelistener_fuzzer.cpp b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/objectservicelistener_fuzzer.cpp new file mode 100644 index 0000000000000000000000000000000000000000..f277dab79370b527ffde31320a821b31ebb08c50 --- /dev/null +++ b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/objectservicelistener_fuzzer.cpp @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2025 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include + +#include "objectservicelistener_fuzzer.h" +#include "object_data_listener.h" + +using namespace OHOS::DistributedObject; + +namespace OHOS { +void OnStartFuzzTest(FuzzedDataProvider &provider) +{ + std::shared_ptr objectAssetsRecvListener = std::make_shared(); + std::string srcNetworkId = provider.ConsumeRandomLengthString(100); + std::string dstNetworkId = provider.ConsumeRandomLengthString(100); + std::string sessionId = provider.ConsumeRandomLengthString(100); + std::string dstBundleName = provider.ConsumeRandomLengthString(100); + objectAssetsRecvListener->OnStart(srcNetworkId, dstNetworkId, sessionId, dstBundleName); +} + +void OnFinishedFuzzTest(FuzzedDataProvider &provider) +{ + std::shared_ptr objectAssetsRecvListener = std::make_shared(); + std::string srcNetworkId = provider.ConsumeRandomLengthString(100); + int32_t result = provider.ConsumeIntegral(); + sptr assetObj = new AssetObj(); + objectAssetsRecvListener->OnFinished(srcNetworkId, assetObj, result); +} + +void OnRecvProgressFuzzTest(FuzzedDataProvider &provider) +{ + std::shared_ptr objectAssetsRecvListener = std::make_shared(); + std::string srcNetworkId = provider.ConsumeRandomLengthString(100); + uint64_t totalBytes = provider.ConsumeIntegral(); + uint64_t processBytes = provider.ConsumeIntegral(); + sptr assetObj1 = new AssetObj(); + objectAssetsRecvListener->OnRecvProgress(srcNetworkId, assetObj1, totalBytes, processBytes); +} +} // namespace OHOS + +/* Fuzzer entry point */ +extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) +{ + FuzzedDataProvider provider(data, size); + OHOS::OnStartFuzzTest(provider); + OHOS::OnFinishedFuzzTest(provider); + OHOS::OnRecvProgressFuzzTest(provider); + return 0; +} \ No newline at end of file diff --git a/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/objectservicelistener_fuzzer.h b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/objectservicelistener_fuzzer.h new file mode 100644 index 0000000000000000000000000000000000000000..355f79d97bb7aec2e92714bdc41075e2f639526c --- /dev/null +++ b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/objectservicelistener_fuzzer.h @@ -0,0 +1,21 @@ +/* + * Copyright (c) 2025 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef OBJECT_SERVICE_LISTENER_FUZZER_H +#define OBJECT_SERVICE_LISTENER_FUZZER_H + +#define FUZZ_PROJECT_NAME "objectservicelistener_fuzzer" + +#endif // OBJECT_SERVICE_LISTENER_FUZZER_H \ No newline at end of file diff --git a/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/project.xml b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/project.xml new file mode 100644 index 0000000000000000000000000000000000000000..a37a23b1533f07ab59744732b0f46b2b5fd958d8 --- /dev/null +++ b/services/distributeddataservice/service/test/fuzztest/objectservicelistener_fuzzer/project.xml @@ -0,0 +1,25 @@ + + + + + + 1000 + + 300 + + 4096 + + \ No newline at end of file diff --git a/services/distributeddataservice/service/test/fuzztest/syncstrategies_fuzzer/syncstrategies_fuzzer.cpp b/services/distributeddataservice/service/test/fuzztest/syncstrategies_fuzzer/syncstrategies_fuzzer.cpp index a29c25be20acbd67434ccc072634f59808b6a423..2cf4591d3c4c8b83f6508c7d232574e4631d37e3 100644 --- a/services/distributeddataservice/service/test/fuzztest/syncstrategies_fuzzer/syncstrategies_fuzzer.cpp +++ b/services/distributeddataservice/service/test/fuzztest/syncstrategies_fuzzer/syncstrategies_fuzzer.cpp @@ -24,7 +24,7 @@ namespace OHOS { void SyncStrategiesFuzz001(FuzzedDataProvider &provider) { int32_t user = provider.ConsumeIntegral(); - std::string bundleName = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); NetworkSyncStrategy strategy; StoreInfo storeInfo; storeInfo.user = user; @@ -42,7 +42,7 @@ void SyncStrategiesFuzz002(FuzzedDataProvider &provider) void SyncStrategiesFuzz003(FuzzedDataProvider &provider) { int32_t user = provider.ConsumeIntegral(); - std::string bundleName = provider.ConsumeRandomLengthString(); + std::string bundleName = provider.ConsumeRandomLengthString(100); NetworkSyncStrategy strategyInstance; strategyInstance.GetStrategy(user, bundleName); strategyInstance.GetKey(user); @@ -51,8 +51,8 @@ void SyncStrategiesFuzz003(FuzzedDataProvider &provider) info.user = 1; info.bundleName = "StrategyInfo"; Serializable::json node; - std::string key = provider.ConsumeRandomLengthString(); - std::string valueStr = provider.ConsumeRandomLengthString(); + std::string key = provider.ConsumeRandomLengthString(100); + std::string valueStr = provider.ConsumeRandomLengthString(100); int valueInt = provider.ConsumeIntegral(); float valueFloat = provider.ConsumeFloatingPoint(); bool valueBool = provider.ConsumeBool();