/*
* Copyright 2012-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.testrunner;
import static com.facebook.buck.testutil.OutputHelper.containsBuckTestOutputLine;
import static org.hamcrest.Matchers.containsString;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat;
import com.facebook.buck.testutil.integration.ProjectWorkspace;
import com.facebook.buck.testutil.integration.ProjectWorkspace.ProcessResult;
import com.facebook.buck.testutil.integration.TemporaryPaths;
import com.facebook.buck.testutil.integration.TestDataHelper;
import java.io.IOException;
import org.junit.Rule;
import org.junit.Test;
public class BuildThenTestIntegrationTest {
@Rule public TemporaryPaths temporaryFolder = new TemporaryPaths();
/**
* It is possible to build a test without running it. It is important to make sure that even
* though a test built successfully, it knows that it needs to run itself if its results are not
* available.
*/
@Test
public void testBuildThenTest() throws IOException {
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "build_then_test", temporaryFolder);
workspace.setUp();
ProcessResult buildResult = workspace.runBuckCommand("build", "//:example");
buildResult.assertSuccess("Successful build should exit with 0.");
ProcessResult testResult = workspace.runBuckCommand("test", "//:example");
assertEquals("", testResult.getStdout());
assertThat(
"Should contain a line indicating what target it is testing",
testResult.getStderr(),
containsString("TESTING //:example"));
assertThat(
"Should contain results from the target.",
testResult.getStderr(),
containsBuckTestOutputLine("PASS", 1, 0, 0, "com.example.MyTest"));
assertThat(
"Should contain a line indicating that tests passed.",
testResult.getStderr(),
containsString("TESTS PASSED"));
testResult.assertSuccess("Passing tests should exit with 0.");
workspace.verify();
}
/** Test should pass even when we run tests on non JUnit test classes */
@Test
public void testRunningTestOnClassWithoutTestMethods() throws IOException {
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "build_then_test", temporaryFolder);
workspace.setUp();
ProcessResult testResult = workspace.runBuckCommand("test", "//:nontestclass");
testResult.assertSuccess("Passing test should exit with 0.");
}
/**
* Test should not be run because the base class is abstract. If the test attempts to run, it will
* throw a java.lang.InstantiationException.
*/
@Test
public void testRunningTestInAbstractClass() throws IOException {
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "build_then_test", temporaryFolder);
workspace.setUp();
ProcessResult testResult = workspace.runBuckCommand("test", "//:abstractclass");
testResult.assertSuccess("Abstract class with test methods should exit with 0.");
}
}