org.gradle.integtests.composite.AbstractCompositeBuildIntegrationTest.groovy Maven / Gradle / Ivy
/*
* Copyright 2016 the original author or authors.
*
* 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 org.gradle.integtests.composite
import com.google.common.collect.Lists
import org.gradle.api.internal.tasks.execution.ExecuteTaskBuildOperationType
import org.gradle.integtests.fixtures.AbstractIntegrationSpec
import org.gradle.integtests.fixtures.BuildOperationsFixture
import org.gradle.integtests.fixtures.build.BuildTestFile
import org.gradle.integtests.fixtures.executer.ExecutionResult
import org.gradle.internal.operations.BuildOperationType
import org.gradle.launcher.exec.RunBuildBuildOperationType
import org.gradle.test.fixtures.file.TestFile
/**
* Tests for composite build.
*/
abstract class AbstractCompositeBuildIntegrationTest extends AbstractIntegrationSpec {
BuildTestFile buildA
List includedBuilds = []
def operations = new BuildOperationsFixture(executer, temporaryFolder)
def setup() {
buildTestFixture.withBuildInSubDir()
buildA = singleProjectBuild("buildA") {
buildFile << """
apply plugin: 'java'
repositories {
maven { url "${mavenRepo.uri}" }
}
"""
}
}
def dependency(BuildTestFile sourceBuild = buildA, String notation) {
sourceBuild.buildFile << """
dependencies {
implementation '${notation}'
}
"""
}
def platformDependency(BuildTestFile sourceBuild = buildA, String notation) {
sourceBuild.buildFile << """
dependencies {
implementation platform('${notation}')
}
"""
}
def includeBuildAs(File build, String name) {
buildA.settingsFile << """
includeBuild('${build.toURI()}') {
name = '$name'
}
"""
}
def includeBuild(File build, def mappings = "") {
if (mappings == "") {
buildA.settingsFile << """
includeBuild('${build.toURI()}')
"""
} else {
buildA.settingsFile << """
includeBuild('${build.toURI()}') {
dependencySubstitution {
$mappings
}
}
"""
}
}
def includePluginBuild(File build) {
buildA.settingsFile.setText("""
pluginManagement {
includeBuild('${build.toURI()}')
}
${buildA.settingsFile.text}
""")
}
protected void execute(BuildTestFile build, String[] tasks, Iterable arguments = []) {
prepare(arguments)
succeeds(build, tasks)
assertSingleBuildOperationsTreeOfType(RunBuildBuildOperationType)
}
protected void execute(BuildTestFile build, String task, Iterable arguments = []) {
prepare(arguments)
succeeds(build, task)
assertSingleBuildOperationsTreeOfType(RunBuildBuildOperationType)
}
protected ExecutionResult succeeds(BuildTestFile build, String... tasks) {
executer.inDirectory(build)
return succeeds(tasks)
}
protected void fails(BuildTestFile build, String task, Iterable arguments = []) {
prepare(arguments)
executer.inDirectory(build)
fails(task)
assertSingleBuildOperationsTreeOfType(RunBuildBuildOperationType)
}
private void prepare(Iterable arguments) {
List includedBuilds = Lists.newArrayList(includedBuilds)
includedBuilds.each {
includeBuild(it)
}
for (String arg : arguments) {
executer.withArgument(arg)
}
}
protected void executed(String... tasks) {
for (String task : tasks) {
result.assertTaskExecuted(task)
}
}
void assertTaskExecuted(String build, String taskPath) {
assert operations.first(ExecuteTaskBuildOperationType) {
it.details.buildPath == build && it.details.taskPath == taskPath
}
}
void assertTaskExecutedOnce(String build, String taskPath) {
operations.only(ExecuteTaskBuildOperationType) {
it.details.buildPath == build && it.details.taskPath == taskPath
}
}
void assertTaskNotExecuted(String build, String taskPath) {
operations.none(ExecuteTaskBuildOperationType) {
it.details.buildPath == build && it.details.taskPath == taskPath
}
}
private > void assertSingleBuildOperationsTreeOfType(Class type) {
assert operations.root(type) != null
}
TestFile getRootDir() {
temporaryFolder.testDirectory
}
def applyPlugin(BuildTestFile build, String name = "pluginBuild") {
build.buildFile << """
buildscript {
dependencies {
classpath 'org.test:$name:1.0'
}
}
apply plugin: 'org.test.plugin.$name'
"""
}
def pluginProjectBuild(String name) {
singleProjectBuild(name) {
pluginProjectBuild(delegate)
}
}
def pluginProjectBuild(BuildTestFile testFile) {
def baseName = testFile.name.capitalize()
def className = baseName + "Impl"
testFile.with {
it.buildFile << """
apply plugin: 'java-gradle-plugin'
gradlePlugin {
plugins {
${it.name} {
id = "org.test.plugin.${it.name}"
implementationClass = "org.test.${className}"
}
}
}
"""
it.file("src/main/java/org/test/${className}.java") << """
package org.test;
import org.gradle.api.Plugin;
import org.gradle.api.Project;
import org.gradle.api.Task;
public class ${className} implements Plugin {
public void apply(Project project) {
Task task = project.task("taskFrom${baseName}");
task.setGroup("Plugin");
}
}
"""
}
}
void outputContains(String string) {
// intentionally override outputContains, because this test may find messages
// which are after the build finished message
def output = result.output
assert output.contains(string.trim())
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy