blob: fd0a1692208d639d78cfcbd22ed1415c0d479e8c [file] [log] [blame]
/*
* Copyright (C) 2015 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.
*/
package com.android.tradefed.result;
import static org.mockito.Mockito.mock;
import com.android.ddmlib.testrunner.TestResult.TestStatus;
import com.android.tradefed.config.ConfigurationException;
import com.android.tradefed.config.OptionSetter;
import com.android.tradefed.invoker.IInvocationContext;
import com.google.common.truth.Truth;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
import java.io.ByteArrayOutputStream;
import java.io.PrintStream;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
/** Unit tests for {@link ConsoleResultReporterTest} */
@RunWith(JUnit4.class)
public class ConsoleResultReporterTest {
private ConsoleResultReporter mResultReporter;
private TestDescription mTest;
private ByteArrayOutputStream mOutput;
@Before
public void setUp() {
mOutput = new ByteArrayOutputStream();
mTest = new TestDescription("FooTest", "testFoo");
mResultReporter = new ConsoleResultReporter(new PrintStream(mOutput, true));
mResultReporter.invocationStarted(mock(IInvocationContext.class));
}
@Test
public void testPassed() {
mResultReporter.testResult(mTest, createTestResult(TestStatus.PASSED));
Truth.assertThat(mOutput.toString()).contains("FooTest#testFoo");
}
@Test
public void testPassed_suppressedPassed() throws ConfigurationException {
new OptionSetter(mResultReporter).setOptionValue("suppress-passed-tests", "true");
mResultReporter.testResult(mTest, createTestResult(TestStatus.PASSED));
Truth.assertThat(mOutput.toString()).hasLength(0);
}
@Test
public void testFailed() {
TestResult result = createTestResult(TestStatus.FAILURE);
result.setStackTrace("this is a trace");
mResultReporter.testResult(mTest, result);
Truth.assertThat(mOutput.toString()).contains("FooTest#testFoo");
Truth.assertThat(mOutput.toString()).contains("this is a trace");
}
@Test
public void testFailed_suppressPassed() throws ConfigurationException {
new OptionSetter(mResultReporter).setOptionValue("suppress-passed-tests", "true");
TestResult result = createTestResult(TestStatus.FAILURE);
result.setStackTrace("this is a trace");
mResultReporter.testResult(mTest, result);
Truth.assertThat(mOutput.toString()).contains("FooTest#testFoo");
Truth.assertThat(mOutput.toString()).contains("this is a trace");
}
@Test
public void testSummary() {
mResultReporter.testResult(mTest, createTestResult(TestStatus.PASSED));
mResultReporter.invocationEnded(0);
Truth.assertThat(mOutput.toString()).contains("1 Tests [1 Passed]");
}
@Test
public void testRunMetrics() {
mResultReporter.testRunStarted("runName", 0);
Map<String, String> metrics = new HashMap<>();
metrics.put("metricKey", "metricValue");
mResultReporter.testRunEnded(0, metrics);
Truth.assertThat(mOutput.toString()).contains("runName: metricKey=metricValue");
}
@Test
public void testRunMetrics_empty() {
mResultReporter.testRunStarted("runName", 0);
mResultReporter.testRunEnded(0, Collections.emptyMap());
Truth.assertThat(mOutput.toString()).doesNotContain("runName");
}
private TestResult createTestResult(TestStatus status) {
TestResult result = new TestResult();
result.setStatus(status);
return result;
}
}