diff options
author | Kristóf Marussy <kristof@marussy.com> | 2023-04-09 02:54:51 +0200 |
---|---|---|
committer | Kristóf Marussy <kristof@marussy.com> | 2023-04-09 19:07:32 +0200 |
commit | d904e2150319439053d89c723733463c4810bde9 (patch) | |
tree | 974068147ce55eda08a27f8fa08e833f4f7d701e /buildSrc/src/main/kotlin/tools/refinery/gradle/java-test-fixtures.gradle.kts | |
parent | build: avoid repeating task names in build scripts (diff) | |
download | refinery-d904e2150319439053d89c723733463c4810bde9.tar.gz refinery-d904e2150319439053d89c723733463c4810bde9.tar.zst refinery-d904e2150319439053d89c723733463c4810bde9.zip |
build: organize build scripts into packages
Also take advantage of precompiled Kotlin scripts to write build scripts in a
more straightforward manner through generated accessors.
Might increase memory usage of Gradle.
Diffstat (limited to 'buildSrc/src/main/kotlin/tools/refinery/gradle/java-test-fixtures.gradle.kts')
-rw-r--r-- | buildSrc/src/main/kotlin/tools/refinery/gradle/java-test-fixtures.gradle.kts | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/buildSrc/src/main/kotlin/tools/refinery/gradle/java-test-fixtures.gradle.kts b/buildSrc/src/main/kotlin/tools/refinery/gradle/java-test-fixtures.gradle.kts new file mode 100644 index 00000000..7e599c3f --- /dev/null +++ b/buildSrc/src/main/kotlin/tools/refinery/gradle/java-test-fixtures.gradle.kts | |||
@@ -0,0 +1,31 @@ | |||
1 | package tools.refinery.gradle | ||
2 | |||
3 | import org.gradle.plugins.ide.eclipse.model.AbstractClasspathEntry | ||
4 | import tools.refinery.gradle.utils.EclipseUtils | ||
5 | |||
6 | plugins { | ||
7 | `java-test-fixtures` | ||
8 | id("tools.refinery.gradle.internal.java-conventions") | ||
9 | } | ||
10 | |||
11 | eclipse.classpath { | ||
12 | containsTestFixtures.set(true) | ||
13 | |||
14 | EclipseUtils.whenClasspathFileMerged(file) { eclipseClasspath -> | ||
15 | val hasTest = eclipseClasspath.entries.any { entry -> | ||
16 | entry is AbstractClasspathEntry && entry.entryAttributes["gradle_scope"] == "test" | ||
17 | } | ||
18 | EclipseUtils.patchClasspathEntries(eclipseClasspath) { entry -> | ||
19 | // Workaround https://github.com/gradle/gradle/issues/11845 based on | ||
20 | // https://discuss.gradle.org/t/gradle-used-by-scope-not-correctly-generated-when-the-java-test-fixtures-plugin-is-used/39935/2 | ||
21 | EclipseUtils.patchGradleUsedByScope(entry) { usedBy -> | ||
22 | if (usedBy.contains("main")) { | ||
23 | usedBy += "testFixtures" | ||
24 | } | ||
25 | if (hasTest && usedBy.contains("testFixtures")) { | ||
26 | usedBy += "test" | ||
27 | } | ||
28 | } | ||
29 | } | ||
30 | } | ||
31 | } | ||