Make sure the clean task doesn't break test fixtures (#43641)
Use a dedicated fixture dir.
This commit is contained in:
parent
299a52c17d
commit
0c8294e633
|
@ -41,3 +41,6 @@ html_docs
|
||||||
# random old stuff that we should look at the necessity of...
|
# random old stuff that we should look at the necessity of...
|
||||||
/tmp/
|
/tmp/
|
||||||
eclipse-build
|
eclipse-build
|
||||||
|
|
||||||
|
# projects using testfixtures
|
||||||
|
testfixtures_shared/
|
||||||
|
|
|
@ -35,6 +35,9 @@ import org.gradle.api.tasks.TaskContainer;
|
||||||
import org.gradle.api.tasks.testing.Test;
|
import org.gradle.api.tasks.testing.Test;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.UncheckedIOException;
|
||||||
|
import java.nio.file.Files;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.function.BiConsumer;
|
import java.util.function.BiConsumer;
|
||||||
|
|
||||||
|
@ -50,6 +53,10 @@ public class TestFixturesPlugin implements Plugin<Project> {
|
||||||
"testFixtures", TestFixtureExtension.class, project
|
"testFixtures", TestFixtureExtension.class, project
|
||||||
);
|
);
|
||||||
|
|
||||||
|
ExtraPropertiesExtension ext = project.getExtensions().getByType(ExtraPropertiesExtension.class);
|
||||||
|
File testfixturesDir = project.file("testfixtures_shared");
|
||||||
|
ext.set("testFixturesDir", testfixturesDir);
|
||||||
|
|
||||||
if (project.file(DOCKER_COMPOSE_YML).exists()) {
|
if (project.file(DOCKER_COMPOSE_YML).exists()) {
|
||||||
// convenience boilerplate with build plugin
|
// convenience boilerplate with build plugin
|
||||||
// Can't reference tasks that are implemented in Groovy, use reflection instead
|
// Can't reference tasks that are implemented in Groovy, use reflection instead
|
||||||
|
@ -63,6 +70,14 @@ public class TestFixturesPlugin implements Plugin<Project> {
|
||||||
Task buildFixture = project.getTasks().create("buildFixture");
|
Task buildFixture = project.getTasks().create("buildFixture");
|
||||||
Task pullFixture = project.getTasks().create("pullFixture");
|
Task pullFixture = project.getTasks().create("pullFixture");
|
||||||
Task preProcessFixture = project.getTasks().create("preProcessFixture");
|
Task preProcessFixture = project.getTasks().create("preProcessFixture");
|
||||||
|
preProcessFixture.doFirst((task) -> {
|
||||||
|
try {
|
||||||
|
Files.createDirectories(testfixturesDir.toPath());
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new UncheckedIOException(e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
preProcessFixture.getOutputs().dir(testfixturesDir);
|
||||||
buildFixture.dependsOn(preProcessFixture);
|
buildFixture.dependsOn(preProcessFixture);
|
||||||
pullFixture.dependsOn(preProcessFixture);
|
pullFixture.dependsOn(preProcessFixture);
|
||||||
Task postProcessFixture = project.getTasks().create("postProcessFixture");
|
Task postProcessFixture = project.getTasks().create("postProcessFixture");
|
||||||
|
@ -90,6 +105,9 @@ public class TestFixturesPlugin implements Plugin<Project> {
|
||||||
pullFixture.dependsOn(tasks.getByName("composePull"));
|
pullFixture.dependsOn(tasks.getByName("composePull"));
|
||||||
tasks.getByName("composeUp").mustRunAfter(preProcessFixture);
|
tasks.getByName("composeUp").mustRunAfter(preProcessFixture);
|
||||||
tasks.getByName("composePull").mustRunAfter(preProcessFixture);
|
tasks.getByName("composePull").mustRunAfter(preProcessFixture);
|
||||||
|
tasks.getByName("composeDown").doLast((task) -> {
|
||||||
|
project.delete(testfixturesDir);
|
||||||
|
});
|
||||||
|
|
||||||
configureServiceInfoForTask(
|
configureServiceInfoForTask(
|
||||||
postProcessFixture,
|
postProcessFixture,
|
||||||
|
|
|
@ -29,14 +29,14 @@ List<String> services = ["peppa", "hdfs"]
|
||||||
preProcessFixture.doLast {
|
preProcessFixture.doLast {
|
||||||
// We need to create these up-front because if docker creates them they will be owned by root and we won't be
|
// We need to create these up-front because if docker creates them they will be owned by root and we won't be
|
||||||
// able to clean them up
|
// able to clean them up
|
||||||
services.each { file("${buildDir}/shared/${it}").mkdirs() }
|
services.each { file("${testFixturesDir}/shared/${it}").mkdirs() }
|
||||||
}
|
}
|
||||||
|
|
||||||
postProcessFixture {
|
postProcessFixture {
|
||||||
inputs.dir("${buildDir}/shared")
|
inputs.dir("${testFixturesDir}/shared")
|
||||||
services.each { service ->
|
services.each { service ->
|
||||||
File confTemplate = file("${buildDir}/shared/${service}/krb5.conf.template")
|
File confTemplate = file("${testFixturesDir}/shared/${service}/krb5.conf.template")
|
||||||
File confFile = file("${buildDir}/shared/${service}/krb5.conf")
|
File confFile = file("${testFixturesDir}/shared/${service}/krb5.conf")
|
||||||
outputs.file(confFile)
|
outputs.file(confFile)
|
||||||
doLast {
|
doLast {
|
||||||
assert confTemplate.exists()
|
assert confTemplate.exists()
|
||||||
|
@ -47,7 +47,7 @@ postProcessFixture {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
project.ext.krb5Conf = { service -> file("$buildDir/shared/${service}/krb5.conf") }
|
project.ext.krb5Conf = { service -> file("$testFixturesDir/shared/${service}/krb5.conf") }
|
||||||
project.ext.krb5Keytabs = { service, fileName -> file("$buildDir/shared/${service}/keytabs/${fileName}") }
|
project.ext.krb5Keytabs = { service, fileName -> file("$testFixturesDir/shared/${service}/keytabs/${fileName}") }
|
||||||
|
|
||||||
test.enabled = false
|
test.enabled = false
|
||||||
|
|
|
@ -7,7 +7,7 @@ services:
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
command: "bash /fixture/src/main/resources/provision/peppa.sh"
|
command: "bash /fixture/src/main/resources/provision/peppa.sh"
|
||||||
volumes:
|
volumes:
|
||||||
- ./build/shared/peppa:/fixture/build
|
- ./testfixtures_shared/shared/peppa:/fixture/build
|
||||||
# containers have bad entropy so mount /dev/urandom. Less secure but this is a test fixture.
|
# containers have bad entropy so mount /dev/urandom. Less secure but this is a test fixture.
|
||||||
- /dev/urandom:/dev/random
|
- /dev/urandom:/dev/random
|
||||||
ports:
|
ports:
|
||||||
|
@ -20,7 +20,7 @@ services:
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
command: "bash /fixture/src/main/resources/provision/hdfs.sh"
|
command: "bash /fixture/src/main/resources/provision/hdfs.sh"
|
||||||
volumes:
|
volumes:
|
||||||
- ./build/shared/hdfs:/fixture/build
|
- ./testfixtures_shared/shared/hdfs:/fixture/build
|
||||||
# containers have bad entropy so mount /dev/urandom. Less secure but this is a test fixture.
|
# containers have bad entropy so mount /dev/urandom. Less secure but this is a test fixture.
|
||||||
- /dev/urandom:/dev/random
|
- /dev/urandom:/dev/random
|
||||||
ports:
|
ports:
|
||||||
|
|
Loading…
Reference in New Issue