/*
* Copyright 2015-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.d;
import static org.junit.Assert.assertTrue;
import com.facebook.buck.testutil.integration.ProjectWorkspace;
import com.facebook.buck.testutil.integration.TemporaryPaths;
import com.facebook.buck.testutil.integration.TestDataHelper;
import org.junit.Rule;
import org.junit.Test;
public class DTestIntegrationTest {
@Rule public TemporaryPaths tmp = new TemporaryPaths();
@Test
public void failingTest() throws Exception {
Assumptions.assumeDCompilerUsable();
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "test", tmp);
workspace.setUp();
ProjectWorkspace.ProcessResult result =
workspace.runBuckCommand("test", "-v", "10", "//:failing_test");
result.assertTestFailure();
assertTrue(
"test reports correct location on failure. stderr:\n" + result.getStderr(),
result.getStderr().matches("(?s:.*)failing_test(?:\\.d)?\\(4\\)(?s:.*)"));
}
@Test
public void passingTest() throws Exception {
Assumptions.assumeDCompilerUsable();
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "test", tmp);
workspace.setUp();
ProjectWorkspace.ProcessResult result =
workspace.runBuckCommand("test", "-v", "10", "//:passing_test");
result.assertSuccess();
}
@Test
public void testDTestTimeout() throws Exception {
Assumptions.assumeDCompilerUsable();
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "test", tmp);
workspace.setUp();
ProjectWorkspace.ProcessResult result =
workspace.runBuckCommand("test", "-v", "10", "//:test-spinning");
result.assertSpecialExitCode("test should fail", 42);
String stderr = result.getStderr();
assertTrue(stderr, stderr.contains("Timed out after 500 ms running test command"));
}
@Test
public void withCxx() throws Exception {
Assumptions.assumeDCompilerUsable();
ProjectWorkspace workspace =
TestDataHelper.createProjectWorkspaceForScenario(this, "test", tmp);
workspace.setUp();
ProjectWorkspace.ProcessResult result =
workspace.runBuckCommand("test", "-v", "10", "//:with_cxx");
result.assertSuccess();
}
}