12087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Copyright (C) 2017 The Android Open Source Project
22087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac//
32087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Licensed under the Apache License, Version 2.0 (the "License");
42087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// you may not use this file except in compliance with the License.
52087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// You may obtain a copy of the License at
62087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac//
72087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac//      http://www.apache.org/licenses/LICENSE-2.0
82087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac//
92087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Unless required by applicable law or agreed to in writing, software
102087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// distributed under the License is distributed on an "AS IS" BASIS,
112087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
122087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// See the License for the specific language governing permissions and
132087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// limitations under the License.
142087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
152087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac#pragma once
162087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
179369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac#include <gtest/gtest.h>
189c1debe330006b2b4d5c08a55905789c57369609Yao Chen#include "frameworks/base/cmds/statsd/src/stats_log.pb.h"
192087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac#include "frameworks/base/cmds/statsd/src/statsd_config.pb.h"
202087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac#include "src/StatsLogProcessor.h"
219c1debe330006b2b4d5c08a55905789c57369609Yao Chen#include "src/logd/LogEvent.h"
229def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac#include "src/hash.h"
239def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac#include "src/stats_log_util.h"
249c1debe330006b2b4d5c08a55905789c57369609Yao Chen#include "statslog.h"
252087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
262087716f2bdca90c7c3034d556ac12911bd8018eYangster-macnamespace android {
272087716f2bdca90c7c3034d556ac12911bd8018eYangster-macnamespace os {
282087716f2bdca90c7c3034d556ac12911bd8018eYangster-macnamespace statsd {
292087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
309def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macusing google::protobuf::RepeatedPtrField;
319def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
3287718e283a62660eaa0e39fd780c97a290da988fYangster-mac// Create AtomMatcher proto to simply match a specific atom type.
3387718e283a62660eaa0e39fd780c97a290da988fYangster-macAtomMatcher CreateSimpleAtomMatcher(const string& name, int atomId);
3487718e283a62660eaa0e39fd780c97a290da988fYangster-mac
3515f6bbc24f4d7a3d4481d90a18df33d402ddacbaYangster-mac// Create AtomMatcher proto for temperature atom.
3615f6bbc24f4d7a3d4481d90a18df33d402ddacbaYangster-macAtomMatcher CreateTemperatureAtomMatcher();
3715f6bbc24f4d7a3d4481d90a18df33d402ddacbaYangster-mac
3813fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster// Create AtomMatcher proto for scheduled job state changed.
3913fb7e4eeaf7aee408821afe7ee55a5167e49e59YangsterAtomMatcher CreateScheduledJobStateChangedAtomMatcher();
4013fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster
4113fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster// Create AtomMatcher proto for starting a scheduled job.
4213fb7e4eeaf7aee408821afe7ee55a5167e49e59YangsterAtomMatcher CreateStartScheduledJobAtomMatcher();
4313fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster
4413fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster// Create AtomMatcher proto for a scheduled job is done.
4513fb7e4eeaf7aee408821afe7ee55a5167e49e59YangsterAtomMatcher CreateFinishScheduledJobAtomMatcher();
4613fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster
479369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create AtomMatcher proto for screen brightness state changed.
489369446f0b04945d6674550728ae81196d6fb5c2Yangster-macAtomMatcher CreateScreenBrightnessChangedAtomMatcher();
499369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
509369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create AtomMatcher proto for starting battery save mode.
519369446f0b04945d6674550728ae81196d6fb5c2Yangster-macAtomMatcher CreateBatterySaverModeStartAtomMatcher();
529369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
539369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create AtomMatcher proto for stopping battery save mode.
549369446f0b04945d6674550728ae81196d6fb5c2Yangster-macAtomMatcher CreateBatterySaverModeStopAtomMatcher();
559369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
569369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create AtomMatcher proto for process state changed.
579369446f0b04945d6674550728ae81196d6fb5c2Yangster-macAtomMatcher CreateUidProcessStateChangedAtomMatcher();
589369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
592087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for acquiring wakelock.
602087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateAcquireWakelockAtomMatcher();
612087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
622087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for releasing wakelock.
632087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateReleaseWakelockAtomMatcher() ;
642087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
652087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for screen turned on.
662087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateScreenTurnedOnAtomMatcher();
672087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
682087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for screen turned off.
692087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateScreenTurnedOffAtomMatcher();
702087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
712087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for app sync turned on.
722087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateSyncStartAtomMatcher();
732087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
742087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for app sync turned off.
752087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateSyncEndAtomMatcher();
762087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
772087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for app sync moves to background.
782087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateMoveToBackgroundAtomMatcher();
792087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
802087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for app sync moves to foreground.
812087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateMoveToForegroundAtomMatcher();
822087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
832087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create AtomMatcher proto for process crashes
842087716f2bdca90c7c3034d556ac12911bd8018eYangster-macAtomMatcher CreateProcessCrashAtomMatcher() ;
852087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
862087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create Predicate proto for screen is on.
872087716f2bdca90c7c3034d556ac12911bd8018eYangster-macPredicate CreateScreenIsOnPredicate();
882087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
892087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create Predicate proto for screen is off.
902087716f2bdca90c7c3034d556ac12911bd8018eYangster-macPredicate CreateScreenIsOffPredicate();
912087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
9213fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster// Create Predicate proto for a running scheduled job.
9313fb7e4eeaf7aee408821afe7ee55a5167e49e59YangsterPredicate CreateScheduledJobPredicate();
9413fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster
959369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create Predicate proto for battery saver mode.
969369446f0b04945d6674550728ae81196d6fb5c2Yangster-macPredicate CreateBatterySaverModePredicate();
979369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
982087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create Predicate proto for holding wakelock.
992087716f2bdca90c7c3034d556ac12911bd8018eYangster-macPredicate CreateHoldingWakelockPredicate();
1002087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1012087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create a Predicate proto for app syncing.
1022087716f2bdca90c7c3034d556ac12911bd8018eYangster-macPredicate CreateIsSyncingPredicate();
1032087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1042087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create a Predicate proto for app is in background.
1052087716f2bdca90c7c3034d556ac12911bd8018eYangster-macPredicate CreateIsInBackgroundPredicate();
1062087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1072087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Add a predicate to the predicate combination.
1082087716f2bdca90c7c3034d556ac12911bd8018eYangster-macvoid addPredicateToPredicateCombination(const Predicate& predicate, Predicate* combination);
1092087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1102087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create dimensions from primitive fields.
1112087716f2bdca90c7c3034d556ac12911bd8018eYangster-macFieldMatcher CreateDimensions(const int atomId, const std::vector<int>& fields);
1122087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1132087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create dimensions by attribution uid and tag.
1142087716f2bdca90c7c3034d556ac12911bd8018eYangster-macFieldMatcher CreateAttributionUidAndTagDimensions(const int atomId,
1152087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac                                                  const std::vector<Position>& positions);
1162087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1172087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create dimensions by attribution uid only.
1182087716f2bdca90c7c3034d556ac12911bd8018eYangster-macFieldMatcher CreateAttributionUidDimensions(const int atomId,
1192087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac                                            const std::vector<Position>& positions);
1202087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1212087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event for screen state changed.
1222087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateScreenStateChangedEvent(
1231a1b0464cb43903ed540f4c43fd423b16e398c04Bookatz    const android::view::DisplayStateEnum state, uint64_t timestampNs);
1242087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1259369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create log event for screen brightness state changed.
1269369446f0b04945d6674550728ae81196d6fb5c2Yangster-macstd::unique_ptr<LogEvent> CreateScreenBrightnessChangedEvent(
1279369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac   int level, uint64_t timestampNs);
1289369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
12913fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster// Create log event when scheduled job starts.
13013fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangsterstd::unique_ptr<LogEvent> CreateStartScheduledJobEvent(
13113fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster    const std::vector<AttributionNodeInternal>& attributions,
13213fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster    const string& name, uint64_t timestampNs);
13313fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster
13413fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster// Create log event when scheduled job finishes.
13513fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangsterstd::unique_ptr<LogEvent> CreateFinishScheduledJobEvent(
13613fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster    const std::vector<AttributionNodeInternal>& attributions,
13713fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster    const string& name, uint64_t timestampNs);
13813fb7e4eeaf7aee408821afe7ee55a5167e49e59Yangster
1399369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create log event when battery saver starts.
1409369446f0b04945d6674550728ae81196d6fb5c2Yangster-macstd::unique_ptr<LogEvent> CreateBatterySaverOnEvent(uint64_t timestampNs);
1419369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac// Create log event when battery saver stops.
1429369446f0b04945d6674550728ae81196d6fb5c2Yangster-macstd::unique_ptr<LogEvent> CreateBatterySaverOffEvent(uint64_t timestampNs);
1439369446f0b04945d6674550728ae81196d6fb5c2Yangster-mac
1442087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event for app moving to background.
1452087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateMoveToBackgroundEvent(const int uid, uint64_t timestampNs);
1462087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1472087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event for app moving to foreground.
1482087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateMoveToForegroundEvent(const int uid, uint64_t timestampNs);
1492087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1502087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event when the app sync starts.
1512087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateSyncStartEvent(
1529c1debe330006b2b4d5c08a55905789c57369609Yao Chen        const std::vector<AttributionNodeInternal>& attributions, const string& name,
1539c1debe330006b2b4d5c08a55905789c57369609Yao Chen        uint64_t timestampNs);
1542087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1552087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event when the app sync ends.
1562087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateSyncEndEvent(
1579c1debe330006b2b4d5c08a55905789c57369609Yao Chen        const std::vector<AttributionNodeInternal>& attributions, const string& name,
1589c1debe330006b2b4d5c08a55905789c57369609Yao Chen        uint64_t timestampNs);
1592087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1602087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event when the app sync ends.
1612087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateAppCrashEvent(
1622087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac    const int uid, uint64_t timestampNs);
1632087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1642087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event for acquiring wakelock.
1652087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateAcquireWakelockEvent(
1669c1debe330006b2b4d5c08a55905789c57369609Yao Chen        const std::vector<AttributionNodeInternal>& attributions, const string& wakelockName,
1679c1debe330006b2b4d5c08a55905789c57369609Yao Chen        uint64_t timestampNs);
1682087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1692087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create log event for releasing wakelock.
1702087716f2bdca90c7c3034d556ac12911bd8018eYangster-macstd::unique_ptr<LogEvent> CreateReleaseWakelockEvent(
1719c1debe330006b2b4d5c08a55905789c57369609Yao Chen        const std::vector<AttributionNodeInternal>& attributions, const string& wakelockName,
1729c1debe330006b2b4d5c08a55905789c57369609Yao Chen        uint64_t timestampNs);
1732087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
174d40053eb8bcb19c7c3b080a36714566bb4e4a748Yangster-mac// Create log event for releasing wakelock.
175d40053eb8bcb19c7c3b080a36714566bb4e4a748Yangster-macstd::unique_ptr<LogEvent> CreateIsolatedUidChangedEvent(
176d40053eb8bcb19c7c3b080a36714566bb4e4a748Yangster-mac    int isolatedUid, int hostUid, bool is_create, uint64_t timestampNs);
177d40053eb8bcb19c7c3b080a36714566bb4e4a748Yangster-mac
1789c1debe330006b2b4d5c08a55905789c57369609Yao Chen// Helper function to create an AttributionNodeInternal proto.
1799c1debe330006b2b4d5c08a55905789c57369609Yao ChenAttributionNodeInternal CreateAttribution(const int& uid, const string& tag);
1802087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1812087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Create a statsd log event processor upon the start time in seconds, config and key.
18215f6bbc24f4d7a3d4481d90a18df33d402ddacbaYangster-macsp<StatsLogProcessor> CreateStatsLogProcessor(const int64_t timeBaseNs,
18315f6bbc24f4d7a3d4481d90a18df33d402ddacbaYangster-mac                                              const int64_t currentTimeNs,
18415f6bbc24f4d7a3d4481d90a18df33d402ddacbaYangster-mac                                              const StatsdConfig& config, const ConfigKey& key);
1852087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
1862087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac// Util function to sort the log events by timestamp.
1872087716f2bdca90c7c3034d556ac12911bd8018eYangster-macvoid sortLogEventsByTimestamp(std::vector<std::unique_ptr<LogEvent>> *events);
1882087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac
18994e197cceb2ba7df13ff8de04f60bfeec64015d9Yangster-macint64_t StringToId(const string& str);
19094e197cceb2ba7df13ff8de04f60bfeec64015d9Yangster-mac
191e06cfd777a501eca17f8dd796b32ad61002c5875Yangster-macvoid ValidateUidDimension(const DimensionsValue& value, int node_idx, int atomId, int uid);
192b5bc74122fb95c81bedad625160fb8d144a863cdYangster-macvoid ValidateAttributionUidDimension(const DimensionsValue& value, int atomId, int uid);
193b5bc74122fb95c81bedad625160fb8d144a863cdYangster-macvoid ValidateAttributionUidAndTagDimension(
194b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac    const DimensionsValue& value, int atomId, int uid, const std::string& tag);
195e06cfd777a501eca17f8dd796b32ad61002c5875Yangster-macvoid ValidateAttributionUidAndTagDimension(
196e06cfd777a501eca17f8dd796b32ad61002c5875Yangster-mac    const DimensionsValue& value, int node_idx, int atomId, int uid, const std::string& tag);
197b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac
1988a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chenstruct DimensionsPair {
1998a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen    DimensionsPair(DimensionsValue m1, DimensionsValue m2) : dimInWhat(m1), dimInCondition(m2){};
2008a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen
2018a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen    DimensionsValue dimInWhat;
2028a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen    DimensionsValue dimInCondition;
2038a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen};
2048a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen
2058a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chenbool LessThan(const DimensionsValue& s1, const DimensionsValue& s2);
2068a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chenbool LessThan(const DimensionsPair& s1, const DimensionsPair& s2);
2078a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen
2089def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2099def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStartEndTimestamp(ConfigMetricsReport *config_report);
2109def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStartEndTimestamp(ConfigMetricsReportList *config_report_list);
2119def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2129def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStringInReport(ConfigMetricsReportList *config_report_list);
2139def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStringInDimension(const std::map<uint64_t, string>& str_map,
2149def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                               DimensionsValue* dimension);
2159def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2169def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mactemplate <typename T>
2179def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStringInDimension(const std::map<uint64_t, string>& str_map,
2189def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                               T* metrics) {
2199def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    for (int i = 0; i < metrics->data_size(); ++i) {
2209def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        auto data = metrics->mutable_data(i);
2219def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        if (data->has_dimensions_in_what()) {
2229def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            backfillStringInDimension(str_map, data->mutable_dimensions_in_what());
2239def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        }
2249def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        if (data->has_dimensions_in_condition()) {
2259def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            backfillStringInDimension(str_map, data->mutable_dimensions_in_condition());
2269def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        }
2279def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    }
2289def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac}
2299def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2309def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillDimensionPath(ConfigMetricsReportList* config_report_list);
2319def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2329def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macbool backfillDimensionPath(const DimensionsValue& path,
2339def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                           const google::protobuf::RepeatedPtrField<DimensionsValue>& leafValues,
2349def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                           DimensionsValue* dimension);
2359def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2369def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mactemplate <typename T>
2379def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillDimensionPath(const DimensionsValue& whatPath,
2389def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                           const DimensionsValue& conditionPath,
2399def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                           T* metricData) {
2409def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    for (int i = 0; i < metricData->data_size(); ++i) {
2419def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        auto data = metricData->mutable_data(i);
2429def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        if (data->dimension_leaf_values_in_what_size() > 0) {
2439def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            backfillDimensionPath(whatPath, data->dimension_leaf_values_in_what(),
2449def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                                  data->mutable_dimensions_in_what());
2459def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            data->clear_dimension_leaf_values_in_what();
2469def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        }
2479def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        if (data->dimension_leaf_values_in_condition_size() > 0) {
2489def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            backfillDimensionPath(conditionPath, data->dimension_leaf_values_in_condition(),
2499def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                                  data->mutable_dimensions_in_condition());
2509def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            data->clear_dimension_leaf_values_in_condition();
2519def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        }
2529def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    }
2539def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac}
2549def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2558a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chenstruct DimensionCompare {
2568a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen    bool operator()(const DimensionsPair& s1, const DimensionsPair& s2) const {
2578a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen        return LessThan(s1, s2);
2588a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen    }
2598a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen};
2608a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen
261b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mactemplate <typename T>
262b5bc74122fb95c81bedad625160fb8d144a863cdYangster-macvoid sortMetricDataByDimensionsValue(const T& metricData, T* sortedMetricData) {
2638a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen    std::map<DimensionsPair, int, DimensionCompare> dimensionIndexMap;
264b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac    for (int i = 0; i < metricData.data_size(); ++i) {
2658a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen        dimensionIndexMap.insert(
2668a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen                std::make_pair(DimensionsPair(metricData.data(i).dimensions_in_what(),
2678a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen                                              metricData.data(i).dimensions_in_condition()),
2688a8d16ceea1e5b7a2f8c41e17b5d993035f50f5dYao Chen                               i));
269b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac    }
270b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac    for (const auto& itr : dimensionIndexMap) {
271b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac        *sortedMetricData->add_data() = metricData.data(itr.second);
272b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac    }
273b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac}
274b5bc74122fb95c81bedad625160fb8d144a863cdYangster-mac
2759def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mactemplate <typename T>
2769def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStartEndTimestampForFullBucket(
2779def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    const int64_t timeBaseNs, const int64_t bucketSizeNs, T* bucket) {
2789def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    bucket->set_start_bucket_elapsed_nanos(timeBaseNs + bucketSizeNs * bucket->bucket_num());
2799def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    bucket->set_end_bucket_elapsed_nanos(
2809def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        timeBaseNs + bucketSizeNs * bucket->bucket_num() + bucketSizeNs);
2819def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    bucket->clear_bucket_num();
2829def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac}
2839def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2849def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mactemplate <typename T>
2859def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStartEndTimestampForPartialBucket(const int64_t timeBaseNs, T* bucket) {
2869def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    if (bucket->has_start_bucket_elapsed_millis()) {
2879def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        bucket->set_start_bucket_elapsed_nanos(
2889def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            MillisToNano(bucket->start_bucket_elapsed_millis()));
2899def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        bucket->clear_start_bucket_elapsed_millis();
2909def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    }
2919def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    if (bucket->has_end_bucket_elapsed_millis()) {
2929def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        bucket->set_end_bucket_elapsed_nanos(
2939def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            MillisToNano(bucket->end_bucket_elapsed_millis()));
2949def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        bucket->clear_end_bucket_elapsed_millis();
2959def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    }
2969def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac}
2979def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
2989def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mactemplate <typename T>
2999def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStartEndTimestampForMetrics(const int64_t timeBaseNs, const int64_t bucketSizeNs,
3009def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                                         T* metrics) {
3019def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    for (int i = 0; i < metrics->data_size(); ++i) {
3029def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        auto data = metrics->mutable_data(i);
3039def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        for (int j = 0; j < data->bucket_info_size(); ++j) {
3049def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            auto bucket = data->mutable_bucket_info(j);
3059def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            if (bucket->has_bucket_num()) {
3069def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                backfillStartEndTimestampForFullBucket(timeBaseNs, bucketSizeNs, bucket);
3079def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            } else {
3089def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac                backfillStartEndTimestampForPartialBucket(timeBaseNs, bucket);
3099def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac            }
3109def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        }
3119def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    }
3129def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac}
3139def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac
3149def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mactemplate <typename T>
3159def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-macvoid backfillStartEndTimestampForSkippedBuckets(const int64_t timeBaseNs, T* metrics) {
3169def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    for (int i = 0; i < metrics->skipped_size(); ++i) {
3179def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac        backfillStartEndTimestampForPartialBucket(timeBaseNs, metrics->mutable_skipped(i));
3189def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac    }
3199def8e3995b1034d943a0fd22b6e512bfacdab77Yangster-mac}
3202087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac}  // namespace statsd
3212087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac}  // namespace os
3222087716f2bdca90c7c3034d556ac12911bd8018eYangster-mac}  // namespace android