blob: 2a4403ed8282e2c7550faa09f8bea46eab719973 [file] [log] [blame]
/*
* Copyright (C) 2018 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 <vector>
#include "benchmark/benchmark.h"
#include "FieldValue.h"
#include "HashableDimensionKey.h"
#include "logd/LogEvent.h"
#include "stats_log_util.h"
namespace android {
namespace os {
namespace statsd {
using std::vector;
static void createLogEventAndLink(LogEvent* event, Metric2Condition *link) {
AttributionNodeInternal node;
node.set_uid(100);
node.set_tag("LOCATION");
std::vector<AttributionNodeInternal> nodes = {node, node};
event->write(nodes);
event->write(3.2f);
event->write("LOCATION");
event->write((int64_t)990);
event->init();
link->conditionId = 1;
FieldMatcher field_matcher;
field_matcher.set_field(event->GetTagId());
auto child = field_matcher.add_child();
child->set_field(1);
child->set_position(FIRST);
child->add_child()->set_field(1);
translateFieldMatcher(field_matcher, &link->metricFields);
field_matcher.set_field(event->GetTagId() + 1);
translateFieldMatcher(field_matcher, &link->conditionFields);
}
static void BM_GetDimensionInCondition(benchmark::State& state) {
Metric2Condition link;
LogEvent event(1, 100000);
createLogEventAndLink(&event, &link);
while (state.KeepRunning()) {
HashableDimensionKey output;
getDimensionForCondition(event.getValues(), link, &output);
}
}
BENCHMARK(BM_GetDimensionInCondition);
} // namespace statsd
} // namespace os
} // namespace android