blob: 5071f58a5bc135d5b9876e3447923950ff4f02b0 [file] [log] [blame]
// Copyright 2017 The Bazel Authors. All rights reserved.
//
// 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.google.devtools.build.lib.actions;
import static com.google.common.truth.Truth.assertThat;
import com.google.common.collect.ImmutableList;
import java.util.List;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
/** Unit tests for {@link ActionResult}. */
@RunWith(JUnit4.class)
public final class ActionResultTest {
@Test
public void testCumulativeCommandExecutionTime_noSpawnResults() {
List<SpawnResult> spawnResults = ImmutableList.of();
ActionResult actionResult = ActionResult.create(spawnResults);
assertThat(actionResult.cumulativeCommandExecutionWallTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionCpuTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionUserTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionSystemTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionBlockOutputOperations()).isNull();
assertThat(actionResult.cumulativeCommandExecutionBlockInputOperations()).isNull();
assertThat(actionResult.cumulativeCommandExecutionInvoluntaryContextSwitches()).isNull();
}
@Test
public void testCumulativeCommandExecutionTime_oneSpawnResult() {
SpawnResult spawnResult =
new SpawnResult.Builder()
.setWallTimeInMs(1984)
.setUserTimeInMs(225)
.setSystemTimeInMs(42)
.setNumBlockOutputOperations(10)
.setNumBlockInputOperations(20)
.setNumInvoluntaryContextSwitches(30)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
List<SpawnResult> spawnResults = ImmutableList.of(spawnResult);
ActionResult actionResult = ActionResult.create(spawnResults);
assertThat(actionResult.cumulativeCommandExecutionWallTimeInMs()).isEqualTo(1984);
assertThat(actionResult.cumulativeCommandExecutionCpuTimeInMs()).isEqualTo(267);
assertThat(actionResult.cumulativeCommandExecutionUserTimeInMs()).isEqualTo(225);
assertThat(actionResult.cumulativeCommandExecutionSystemTimeInMs()).isEqualTo(42);
assertThat(actionResult.cumulativeCommandExecutionBlockOutputOperations()).isEqualTo(10);
assertThat(actionResult.cumulativeCommandExecutionBlockInputOperations()).isEqualTo(20);
assertThat(actionResult.cumulativeCommandExecutionInvoluntaryContextSwitches()).isEqualTo(30);
}
@Test
public void testCumulativeCommandExecutionTime_manySpawnResults() {
SpawnResult spawnResult1 =
new SpawnResult.Builder()
.setWallTimeInMs(1979)
.setUserTimeInMs(1)
.setSystemTimeInMs(33)
.setNumBlockOutputOperations(10)
.setNumBlockInputOperations(20)
.setNumInvoluntaryContextSwitches(30)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult2 =
new SpawnResult.Builder()
.setWallTimeInMs(4)
.setUserTimeInMs(1)
.setSystemTimeInMs(7)
.setNumBlockOutputOperations(100)
.setNumBlockInputOperations(200)
.setNumInvoluntaryContextSwitches(300)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult3 =
new SpawnResult.Builder()
.setWallTimeInMs(1)
.setUserTimeInMs(2)
.setSystemTimeInMs(2)
.setNumBlockOutputOperations(1000)
.setNumBlockInputOperations(2000)
.setNumInvoluntaryContextSwitches(3000)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
List<SpawnResult> spawnResults = ImmutableList.of(spawnResult1, spawnResult2, spawnResult3);
ActionResult actionResult = ActionResult.create(spawnResults);
assertThat(actionResult.cumulativeCommandExecutionWallTimeInMs()).isEqualTo(1984L);
assertThat(actionResult.cumulativeCommandExecutionCpuTimeInMs()).isEqualTo(46L);
assertThat(actionResult.cumulativeCommandExecutionUserTimeInMs()).isEqualTo(4L);
assertThat(actionResult.cumulativeCommandExecutionSystemTimeInMs()).isEqualTo(42L);
assertThat(actionResult.cumulativeCommandExecutionBlockOutputOperations()).isEqualTo(1110L);
assertThat(actionResult.cumulativeCommandExecutionBlockInputOperations()).isEqualTo(2220L);
assertThat(actionResult.cumulativeCommandExecutionInvoluntaryContextSwitches())
.isEqualTo(3330L);
}
@Test
public void testCumulativeCommandExecutionTime_manyEmptySpawnResults() {
SpawnResult spawnResult1 =
new SpawnResult.Builder()
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult2 =
new SpawnResult.Builder()
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult3 =
new SpawnResult.Builder()
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
List<SpawnResult> spawnResults = ImmutableList.of(spawnResult1, spawnResult2, spawnResult3);
ActionResult actionResult = ActionResult.create(spawnResults);
assertThat(actionResult.cumulativeCommandExecutionWallTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionCpuTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionUserTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionSystemTimeInMs()).isEqualTo(0);
assertThat(actionResult.cumulativeCommandExecutionBlockOutputOperations()).isNull();
assertThat(actionResult.cumulativeCommandExecutionBlockInputOperations()).isNull();
assertThat(actionResult.cumulativeCommandExecutionInvoluntaryContextSwitches()).isNull();
}
@Test
public void testCumulativeCommandExecutionTime_manySpawnResults_butOnlyUserTime() {
SpawnResult spawnResult1 =
new SpawnResult.Builder()
.setUserTimeInMs(2)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult2 =
new SpawnResult.Builder()
.setUserTimeInMs(3)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult3 =
new SpawnResult.Builder()
.setUserTimeInMs(4)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
List<SpawnResult> spawnResults = ImmutableList.of(spawnResult1, spawnResult2, spawnResult3);
ActionResult actionResult = ActionResult.create(spawnResults);
assertThat(actionResult.cumulativeCommandExecutionCpuTimeInMs()).isEqualTo(9L);
assertThat(actionResult.cumulativeCommandExecutionUserTimeInMs()).isEqualTo(9L);
}
@Test
public void testCumulativeCommandExecutionTime_manySpawnResults_butOnlySystemTime() {
SpawnResult spawnResult1 =
new SpawnResult.Builder()
.setSystemTimeInMs(33)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult2 =
new SpawnResult.Builder()
.setSystemTimeInMs(7)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
SpawnResult spawnResult3 =
new SpawnResult.Builder()
.setSystemTimeInMs(2)
.setStatus(SpawnResult.Status.SUCCESS)
.setRunnerName("test")
.build();
List<SpawnResult> spawnResults = ImmutableList.of(spawnResult1, spawnResult2, spawnResult3);
ActionResult actionResult = ActionResult.create(spawnResults);
assertThat(actionResult.cumulativeCommandExecutionCpuTimeInMs()).isEqualTo(42L);
assertThat(actionResult.cumulativeCommandExecutionSystemTimeInMs()).isEqualTo(42L);
}
}