// Copyright (C) 2017 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. #pragma once #include "src/condition/ConditionWizard.h" #include "src/external/StatsPullerManager.h" #include "src/packages/UidMap.h" #include #include namespace android { namespace os { namespace statsd { class MockConditionWizard : public ConditionWizard { public: MOCK_METHOD6(query, ConditionState(const int conditionIndex, const ConditionKey& conditionParameters, const vector& dimensionFields, const bool isSubsetDim, const bool isPartialLink, std::unordered_set* dimensionKeySet)); }; class MockStatsPullerManager : public StatsPullerManager { public: MOCK_METHOD4(RegisterReceiver, void(int tagId, wp receiver, int64_t nextPulltimeNs, int64_t intervalNs)); MOCK_METHOD2(UnRegisterReceiver, void(int tagId, wp receiver)); MOCK_METHOD3(Pull, bool(const int pullCode, const int64_t timeNs, vector>* data)); }; class MockUidMap : public UidMap { public: MOCK_CONST_METHOD1(getHostUidOrSelf, int(int uid)); }; HashableDimensionKey getMockedDimensionKey(int tagId, int key, std::string value); MetricDimensionKey getMockedMetricDimensionKey(int tagId, int key, std::string value); // Utils to build FieldMatcher proto for simple one-depth atoms. void buildSimpleAtomFieldMatcher(const int tagId, const int atomFieldNum, FieldMatcher* matcher); void buildSimpleAtomFieldMatcher(const int tagId, FieldMatcher* matcher); } // namespace statsd } // namespace os } // namespace android