/* * Copyright (C) 2016 The Android Open Source Project * * 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 #include #include #include #include "android/aidl/tests/ITestService.h" namespace android { namespace aidl { namespace tests { namespace client { template bool RepeatPrimitive( const android::sp& service, android::binder::Status(android::aidl::tests::ITestService::*func)(T, V*), U input) { V reply; android::binder::Status status = (*service.*func)(input, &reply); if (!status.isOk() || input != reply) { LOG(ERROR) << "Failed to repeat primitive. status=" << status.toString8() << "."; return false; } return true; } template bool ReverseArray( const android::sp& service, android::binder::Status(android::aidl::tests::ITestService::*func)( const std::vector&, std::vector*, std::vector*), std::vector input) { std::vector actual_reversed; std::vector actual_repeated; android::binder::Status status = (*service.*func)( input, &actual_repeated, &actual_reversed); if (!status.isOk()) { LOG(ERROR) << "Failed to repeat array. status=" << status.toString8() << "."; return false; } if (input != actual_repeated) { LOG(ERROR) << "Repeated version of array did not match"; LOG(ERROR) << "input.size()=" << input.size() << " repeated.size()=" << actual_repeated.size(); return false; } std::reverse(input.begin(), input.end()); if (input != actual_reversed) { LOG(ERROR) << "Reversed version of array did not match"; return false; } return true; } } // namespace client } // namespace tests } // namespace aidl } // namespace android