blob: af2e2116c5c45027df8b7d549f46c93923aff1d9 [file] [log] [blame]
// Copyright 2015 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.runtime;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import com.google.common.collect.ImmutableMap;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.exec.ExecutionOptions;
import com.google.devtools.build.lib.exec.TestStrategy.TestSummaryFormat;
import com.google.devtools.build.lib.runtime.TerminalTestResultNotifier.TestSummaryOptions;
import com.google.devtools.build.lib.util.io.AnsiTerminalPrinter;
import com.google.devtools.build.lib.view.test.TestStatus.BlazeTestStatus;
import com.google.devtools.build.lib.view.test.TestStatus.TestCase;
import com.google.devtools.build.lib.view.test.TestStatus.TestCase.Status;
import com.google.devtools.common.options.OptionsParsingResult;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.Random;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
import org.mockito.Mockito;
/** Tests {@link TerminalTestResultNotifier}. */
@RunWith(JUnit4.class)
public class TerminalTestResultNotifierTest {
private final OptionsParsingResult optionsParsingResult =
Mockito.mock(OptionsParsingResult.class);
private final AnsiTerminalPrinter ansiTerminalPrinter = Mockito.mock(AnsiTerminalPrinter.class);
private final Random random = new Random();
private void givenExecutionOption(TestSummaryFormat format) {
ExecutionOptions executionOptions = ExecutionOptions.DEFAULTS;
executionOptions.testSummary = format;
when(optionsParsingResult.getOptions(ExecutionOptions.class)).thenReturn(executionOptions);
TestSummaryOptions testSummaryOptions = new TestSummaryOptions();
testSummaryOptions.verboseSummary = true;
when(optionsParsingResult.getOptions(TestSummaryOptions.class)).thenReturn(testSummaryOptions);
}
private void runTest(Boolean shouldPrintTestCaseSummary) throws Exception {
int numOfTotalTestCases = random.nextInt(10) + 1;
int numOfFailedCases = random.nextInt(numOfTotalTestCases);
int numOfSuccessfulTestCases = numOfTotalTestCases - numOfFailedCases;
TerminalTestResultNotifier terminalTestResultNotifier =
new TerminalTestResultNotifier(ansiTerminalPrinter, optionsParsingResult);
TestSummary testSummary = Mockito.mock(TestSummary.class);
when(testSummary.getTotalTestCases()).thenReturn(numOfTotalTestCases);
TestCase failedTestCase = TestCase.newBuilder().setStatus(Status.FAILED).build();
ArrayList<TestCase> testCases =
new ArrayList<>(Collections.nCopies(numOfFailedCases, failedTestCase));
Label labelA = Label.parseAbsolute("//foo/bar:baz", ImmutableMap.of());
when(testSummary.getFailedTestCases()).thenReturn(testCases);
when(testSummary.getStatus()).thenReturn(BlazeTestStatus.FAILED);
when(testSummary.getLabel()).thenReturn(labelA);
HashSet<TestSummary> testSummaries = new HashSet<>();
testSummaries.add(testSummary);
terminalTestResultNotifier.notify(testSummaries, 1);
String summaryMessage =
String.format(
"Test cases: finished with %s%d passing%s and %s%d failing%s out of %d test cases",
numOfSuccessfulTestCases > 0 ? AnsiTerminalPrinter.Mode.INFO : "",
numOfSuccessfulTestCases,
AnsiTerminalPrinter.Mode.DEFAULT,
numOfFailedCases > 0 ? AnsiTerminalPrinter.Mode.ERROR : "",
numOfFailedCases,
AnsiTerminalPrinter.Mode.DEFAULT,
numOfTotalTestCases);
if (shouldPrintTestCaseSummary) {
verify(ansiTerminalPrinter).printLn(summaryMessage);
} else {
verify(ansiTerminalPrinter, never()).printLn(summaryMessage);
}
}
@Test
public void testCasesDataVisibleInTestCaseOption() throws Exception {
givenExecutionOption(TestSummaryFormat.TESTCASE);
runTest(true);
}
@Test
public void testCasesDataVisibleInDetailedOption() throws Exception {
givenExecutionOption(TestSummaryFormat.DETAILED);
runTest(true);
}
@Test
public void testCasesDataInVisibleInShortOption() throws Exception {
givenExecutionOption(TestSummaryFormat.SHORT);
runTest(false);
}
@Test
public void testCasesDataInVisibleInTerseOption() throws Exception {
givenExecutionOption(TestSummaryFormat.TERSE);
runTest(false);
}
@Test
public void testCasesDataInVisibleInNoneOption() throws Exception {
givenExecutionOption(TestSummaryFormat.NONE);
runTest(false);
}
}