1 // Copyright (C) 2017 The Android Open Source Project 2 // 3 // Licensed under the Apache License, Version 2.0 (the "License"); 4 // you may not use this file except in compliance with the License. 5 // You may obtain a copy of the License at 6 // 7 // http://www.apache.org/licenses/LICENSE-2.0 8 // 9 // Unless required by applicable law or agreed to in writing, software 10 // distributed under the License is distributed on an "AS IS" BASIS, 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 // See the License for the specific language governing permissions and 13 // limitations under the License. 14 #pragma once 15 16 #include "src/condition/ConditionWizard.h" 17 #include "src/external/StatsPullerManager.h" 18 #include "src/packages/UidMap.h" 19 20 #include <gmock/gmock.h> 21 #include <gtest/gtest.h> 22 23 namespace android { 24 namespace os { 25 namespace statsd { 26 27 class MockConditionWizard : public ConditionWizard { 28 public: 29 MOCK_METHOD3(query, 30 ConditionState(const int conditionIndex, const ConditionKey& conditionParameters, 31 const bool isPartialLink)); 32 }; 33 34 class MockStatsPullerManager : public StatsPullerManager { 35 public: 36 MOCK_METHOD5(RegisterReceiver, 37 void(int tagId, const ConfigKey& key, const wp<PullDataReceiver>& receiver, 38 int64_t nextPulltimeNs, int64_t intervalNs)); 39 MOCK_METHOD3(UnRegisterReceiver, 40 void(int tagId, const ConfigKey& key, const wp<PullDataReceiver>& receiver)); 41 MOCK_METHOD4(Pull, bool(const int pullCode, const ConfigKey& key, int64_t eventTimeNs, 42 vector<std::shared_ptr<LogEvent>>* data)); 43 MOCK_METHOD4(Pull, bool(const int pullCode, const vector<int32_t>& uids, 44 const int64_t eventTimeNs, vector<std::shared_ptr<LogEvent>>* data)); 45 MOCK_METHOD2(RegisterPullUidProvider, 46 void(const ConfigKey& configKey, const wp<PullUidProvider>& provider)); 47 MOCK_METHOD2(UnregisterPullUidProvider, 48 void(const ConfigKey& configKey, const wp<PullUidProvider>& provider)); 49 }; 50 51 HashableDimensionKey getMockedDimensionKey(int tagId, int key, std::string value); 52 MetricDimensionKey getMockedMetricDimensionKey(int tagId, int key, std::string value); 53 54 HashableDimensionKey getMockedDimensionKeyLongValue(int tagId, int key, int64_t value); 55 MetricDimensionKey getMockedStateDimensionKey(int tagId, int key, int64_t value); 56 57 // Utils to build FieldMatcher proto for simple one-depth atoms. 58 void buildSimpleAtomFieldMatcher(const int tagId, int atomFieldNum, FieldMatcher* matcher); 59 void buildSimpleAtomFieldMatcher(const int tagId, FieldMatcher* matcher); 60 61 } // namespace statsd 62 } // namespace os 63 } // namespace android 64