/* * Copyright 2017-present Facebook, Inc. * * 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. */ package com.facebook.buck.log; import com.facebook.buck.log.views.JsonViews; import com.facebook.buck.util.immutables.BuckStyleImmutable; import com.fasterxml.jackson.annotation.JsonView; import org.immutables.value.Value; @Value.Immutable @BuckStyleImmutable abstract class AbstractPerfTimesStats { /** @return duration of the time spent in python, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getPythonTimeMs() { return 0L; } /** @return duration Buck spends initializing, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getInitTimeMs() { return 0L; } /** @return time spent between initialization and start of parsing, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getProcessingTimeMs() { return 0L; } /** @return time spent parsing and processing BUCK files, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getParseTimeMs() { return 0L; } /** @return time it takes to generate the action graph, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getActionGraphTimeMs() { return 0L; } /** * @return duration of the rule keys computation, from the start of rule key calculation to the * fetching of the first artifact from the remote cache, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getRulekeyTimeMs() { return 0L; } /** * @return duration of the fetch operation, from the first fetch event to the start of the local * build, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getFetchTimeMs() { return 0L; } /** * @return duration of the local build phase, from start of the local build to when the build * completes, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getBuildTimeMs() { return 0L; } /** @return time it takes to install to a device, in milliseconds. */ @JsonView(JsonViews.MachineReadableLog.class) @Value.Default public Long getInstallTimeMs() { return 0L; } }