1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2025-10-25 10:57:57 +00:00

Fix client tests not running on Forge

This was introduced by the FG6 update - the cctest.client property
didn't get set, and so tests never started!
This commit is contained in:
Jonathan Coates
2023-07-22 19:40:50 +01:00
parent 90ed0b24e7
commit dd08d1ec8e
2 changed files with 26 additions and 8 deletions

View File

@@ -4,6 +4,7 @@
package cc.tweaked.gradle package cc.tweaked.gradle
import net.minecraftforge.gradle.common.util.RunConfig
import org.gradle.api.GradleException import org.gradle.api.GradleException
import org.gradle.api.file.FileSystemOperations import org.gradle.api.file.FileSystemOperations
import org.gradle.api.invocation.Gradle import org.gradle.api.invocation.Gradle
@@ -53,6 +54,25 @@ abstract class ClientJavaExec : JavaExec() {
@get:OutputFile @get:OutputFile
val testResults = project.layout.buildDirectory.file("test-results/$name.xml") val testResults = project.layout.buildDirectory.file("test-results/$name.xml")
private fun setTestProperties() {
if (!clientDebug) systemProperty("cctest.client", "")
if (renderdoc) environment("LD_PRELOAD", "/usr/lib/librenderdoc.so")
systemProperty("cctest.gametest-report", testResults.get().asFile.absoluteFile)
workingDir(project.buildDir.resolve("gametest").resolve(name))
}
init {
setTestProperties()
}
/**
* Set this task to run a given [RunConfig].
*/
fun setRunConfig(config: RunConfig) {
(this as JavaExec).setRunConfig(config)
setTestProperties() // setRunConfig may clobber some properties, ensure everything is set.
}
/** /**
* Copy configuration from a task with the given name. * Copy configuration from a task with the given name.
*/ */
@@ -64,11 +84,7 @@ abstract class ClientJavaExec : JavaExec() {
fun copyFrom(task: JavaExec) { fun copyFrom(task: JavaExec) {
for (dep in task.dependsOn) dependsOn(dep) for (dep in task.dependsOn) dependsOn(dep)
task.copyToFull(this) task.copyToFull(this)
setTestProperties() // copyToFull may clobber some properties, ensure everything is set.
if (!clientDebug) systemProperty("cctest.client", "")
if (renderdoc) environment("LD_PRELOAD", "/usr/lib/librenderdoc.so")
systemProperty("cctest.gametest-report", testResults.get().asFile.absoluteFile)
workingDir(project.buildDir.resolve("gametest").resolve(name))
} }
/** /**

View File

@@ -114,10 +114,12 @@ def main():
images: list[Image] = [] images: list[Image] = []
for project, dir in { for project, dir in {
"Forge": "projects/forge", "Forge": "projects/forge/build/gametest/runGametestClient",
"Fabric": "projects/fabric", "Fabric": "projects/fabric/build/gametest/runGametestClient",
"Fabric (+Sodium)": "projects/fabric/build/gametest/runGametestClientWithSodium",
"Fabric (+Iris)": "projects/fabric/build/gametest/runGametestClientWithIris",
}.items(): }.items():
for file in sorted(pathlib.Path(dir).glob("build/gametest/*/screenshots/*.png")): for file in sorted(pathlib.Path(dir).glob("screenshots/*.png")):
name = [project, *(_normalise_id(x) for x in file.stem.split("."))] name = [project, *(_normalise_id(x) for x in file.stem.split("."))]
mtime = datetime.fromtimestamp(file.stat().st_mtime, tz=timezone.utc) mtime = datetime.fromtimestamp(file.stat().st_mtime, tz=timezone.utc)