17:34:39 Started by user Geolykt
17:34:39 Running as SYSTEM
17:34:39 Building in workspace /var/lib/jenkins/workspace/micromixin
17:34:39 The recommended git tool is: NONE
17:34:39 No credentials specified
17:34:39 > git rev-parse --resolve-git-dir /var/lib/jenkins/workspace/micromixin/.git # timeout=10
17:34:39 Fetching changes from the remote Git repository
17:34:40 > git config remote.origin.url https://github.com/stianloader/Micromixin.git # timeout=10
17:34:40 Fetching upstream changes from https://github.com/stianloader/Micromixin.git
17:34:40 > git --version # timeout=10
17:34:40 > git --version # 'git version 2.54.0'
17:34:40 > git fetch --tags --force --progress -- https://github.com/stianloader/Micromixin.git +refs/heads/*:refs/remotes/origin/* # timeout=10
17:34:40 > git rev-parse refs/remotes/origin/main^{commit} # timeout=10
17:34:40 Checking out Revision 620ccba675bf76d0ac738235e3c743e352ea563f (refs/remotes/origin/main)
17:34:40 > git config core.sparsecheckout # timeout=10
17:34:40 > git checkout -f 620ccba675bf76d0ac738235e3c743e352ea563f # timeout=10
17:34:40 Commit message: "Finalize work on WrapOperation, introduce vendor compatibility system"
17:34:40 > git rev-list --no-walk 620ccba675bf76d0ac738235e3c743e352ea563f # timeout=10
17:34:40 false
17:34:40 [Gradle] - Launching build.
17:34:41 [micromixin] $ /var/lib/jenkins/workspace/micromixin/gradlew -PpublishRepo=http://localhost:25615/maven publish micromixin-testing-suite-neo:runTestSuite
17:34:42 Starting a Gradle Daemon (subsequent builds will be faster)
17:34:55
17:34:55 > Configure project :micromixin-testing-suite-neo
17:34:55 Publishing to http://localhost:25615/maven
17:34:55
17:34:55 > Configure project :micromixin-transformer
17:34:55 Publishing to http://localhost:25615/maven
17:34:58
17:34:58 > Task :micromixin-annotations:compileJava UP-TO-DATE
17:34:58 > Task :micromixin-annotations:processResources NO-SOURCE
17:34:58 > Task :micromixin-annotations:classes UP-TO-DATE
17:34:58 > Task :micromixin-annotations:compileJava9Java NO-SOURCE
17:34:58 > Task :micromixin-annotations:compileJava9moduleJava UP-TO-DATE
17:34:58 > Task :micromixin-annotations:processJava9Resources NO-SOURCE
17:34:58 > Task :micromixin-annotations:java9Classes UP-TO-DATE
17:34:58 > Task :micromixin-annotations:processJava9moduleResources NO-SOURCE
17:34:58 > Task :micromixin-annotations:java9moduleClasses UP-TO-DATE
17:34:58 > Task :micromixin-annotations:jar UP-TO-DATE
17:34:58 > Task :micromixin-annotations:generateMetadataFileForMavenPublication
17:34:58 > Task :micromixin-annotations:generatePomFileForMavenPublication
17:34:58 > Task :micromixin-annotations:javadoc UP-TO-DATE
17:34:58 > Task :micromixin-annotations:javadocJar UP-TO-DATE
17:34:58 > Task :micromixin-annotations:sourcesJar UP-TO-DATE
17:34:59 > Task :micromixin-annotations:publishMavenPublicationToMavenRepository
17:34:59 > Task :micromixin-annotations:publish
17:35:02 > Task :micromixin-backports:compileJava
17:35:02 > Task :micromixin-backports:processResources NO-SOURCE
17:35:02 > Task :micromixin-backports:classes
17:35:02 > Task :micromixin-backports:compileJava9Java NO-SOURCE
17:35:02 > Task :micromixin-backports:compileJava9moduleJava UP-TO-DATE
17:35:02 > Task :micromixin-backports:processJava9Resources NO-SOURCE
17:35:02 > Task :micromixin-backports:java9Classes UP-TO-DATE
17:35:02 > Task :micromixin-backports:processJava9moduleResources NO-SOURCE
17:35:02 > Task :micromixin-backports:java9moduleClasses UP-TO-DATE
17:35:02 > Task :micromixin-backports:jar
17:35:02 > Task :micromixin-backports:generateMetadataFileForMavenPublication
17:35:02 > Task :micromixin-backports:generatePomFileForMavenPublication
17:35:05 > Task :micromixin-backports:javadoc
17:35:05 > Task :micromixin-backports:javadocJar
17:35:05 > Task :micromixin-backports:sourcesJar
17:35:05 > Task :micromixin-backports:publishMavenPublicationToMavenRepository
17:35:05 > Task :micromixin-backports:publish
17:35:10 > Task :micromixin-testing-suite-neo:compileJava
17:35:10 > Task :micromixin-testing-suite-neo:processResources
17:35:10 > Task :micromixin-testing-suite-neo:classes
17:35:10 > Task :micromixin-testing-suite-neo:jar
17:35:10 > Task :micromixin-testing-suite-neo:generateMetadataFileForMavenPublication
17:35:10 > Task :micromixin-testing-suite-neo:generatePomFileForMavenPublication
17:35:10 > Task :micromixin-testing-suite-neo:sourcesJar
17:35:10 > Task :micromixin-testing-suite-neo:publishMavenPublicationToMavenRepository
17:35:10 > Task :micromixin-testing-suite-neo:publish
17:35:12
17:35:12 > Task :micromixin-transformer:compileJava
17:35:12 /var/lib/jenkins/.m2/repository/org/ow2/asm/asm/9.9.1/asm-9.9.1.jar(org/objectweb/asm/Handle.class): warning: Cannot find annotation method 'forRemoval()' in type 'java.lang.Deprecated'
17:35:12 /var/lib/jenkins/.m2/repository/org/ow2/asm/asm/9.9.1/asm-9.9.1.jar(org/objectweb/asm/Opcodes.class): warning: Cannot find annotation method 'forRemoval()' in type 'java.lang.Deprecated'
17:35:12 /var/lib/jenkins/.m2/repository/org/ow2/asm/asm-util/9.9.1/asm-util-9.9.1.jar(org/objectweb/asm/util/Textifier.class): warning: Cannot find annotation method 'forRemoval()' in type 'java.lang.Deprecated'
17:35:12 /var/lib/jenkins/.m2/repository/org/ow2/asm/asm/9.9.1/asm-9.9.1.jar(org/objectweb/asm/MethodVisitor.class): warning: Cannot find annotation method 'forRemoval()' in type 'java.lang.Deprecated'
17:35:12 /var/lib/jenkins/.m2/repository/org/ow2/asm/asm-util/9.9.1/asm-util-9.9.1.jar(org/objectweb/asm/util/Printer.class): warning: Cannot find annotation method 'forRemoval()' in type 'java.lang.Deprecated'
17:35:13 Note: Some input files use or override a deprecated API.
17:35:13 Note: Recompile with -Xlint:deprecation for details.
17:35:13 Note: Some input files use unchecked or unsafe operations.
17:35:13 Note: Recompile with -Xlint:unchecked for details.
17:35:13 5 warnings
17:35:13
17:35:13 > Task :micromixin-transformer:processResources NO-SOURCE
17:35:13 > Task :micromixin-transformer:classes
17:35:13 > Task :micromixin-transformer:compileJava9Java UP-TO-DATE
17:35:17
17:35:17 > Task :micromixin-transformer:compileJava9moduleJava
17:35:17 /var/lib/jenkins/workspace/micromixin/micromixin-transformer/src/main/java9/module-info.java:6: warning: requires transitive directive for an automatic module
17:35:17 requires transitive org.json;
17:35:17 ^
17:35:18 Note: Some input files use or override a deprecated API.
17:35:18 Note: Recompile with -Xlint:deprecation for details.
17:35:18 Note: Some input files use unchecked or unsafe operations.
17:35:18 Note: Recompile with -Xlint:unchecked for details.
17:35:18 1 warning
17:35:19
17:35:19 > Task :micromixin-transformer:processJava9Resources NO-SOURCE
17:35:19 > Task :micromixin-transformer:java9Classes UP-TO-DATE
17:35:19 > Task :micromixin-transformer:processJava9moduleResources NO-SOURCE
17:35:19 > Task :micromixin-transformer:java9moduleClasses
17:35:23 > Task :micromixin-transformer:javadoc
17:35:24 > Task :micromixin-transformer:javadocJar
17:35:24 > Task :micromixin-transformer:sourcesJar
17:35:24 > Task :micromixin-transformer:compileTestJava
17:35:24 > Task :micromixin-transformer:processTestResources NO-SOURCE
17:35:24 > Task :micromixin-transformer:testClasses
17:35:26 > Task :micromixin-transformer:test
17:35:26 > Task :micromixin-transformer:virtualDeprecationJ6
17:35:27 > Task :micromixin-transformer:jar
17:35:27 > Task :micromixin-transformer:generateMetadataFileForMavenPublication
17:35:27 > Task :micromixin-transformer:generatePomFileForMavenPublication
17:35:27 > Task :micromixin-transformer:publishMavenPublicationToMavenRepository
17:35:27 > Task :micromixin-transformer:publish
17:35:31
17:35:31 > Task :micromixin-testing-suite-neo:runTestSuite
17:35:31 ================================================================================
17:35:31 Following modules present: [ch.qos.logback.classic, ch.qos.logback.core, com.google.common, com.google.errorprone.annotations, com.google.gson, de.geolykt.starloader.launcher, de.geolykt.starloader.ras, failureaccess, j2objc.annotations, jsr305, listenablefuture, mixinextras.common, org.checkerframework.checker.qual, org.fusesource.jansi, org.jetbrains.annotations, org.objectweb.asm, org.objectweb.asm.commons, org.objectweb.asm.tree, org.objectweb.asm.tree.analysis, org.objectweb.asm.util, org.slf4j, org.spongepowered.mixin, org.stianloader.micromixin.backports]
17:35:31 Following modules not initialized (you might want to define them as root modules): [org.objectweb.asm, org.objectweb.asm.tree]
17:35:31 'de.geolykt.starloader.launcher.IDELauncher' is loaded by 'null' and is of module 'de.geolykt.starloader.launcher'
17:35:31 Class URL (as per protection domain): file:/var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/.maven/org/stianloader/launcher-mixin-fabric/4.0.0-a20250922/launcher-mixin-fabric-4.0.0-a20250922.jar
17:35:31 [main] [17:35:31.759] [WARN] de.geolykt.starloader.launcher.IDELauncher: Extension directory undefined.
17:35:31 [main] [17:35:31.763] [INFO] de.geolykt.starloader.launcher.IDELauncher: Using prototypes from following sources:
17:35:31 [main] [17:35:31.764] [INFO] de.geolykt.starloader.launcher.IDELauncher: - [file:/var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/build/libs/micromixin-testing-suite-neo-0.9.0.jar]
17:35:31 [main] [17:35:31.809] [INFO] d.g.starloader.launcher.service.SLMixinLogger: SpongePowered MIXIN Subsystem Version=0.8.7 Source=file:/var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/.maven/org/stianloader/sponge-mixin/0.16.4-0.8.7-1-a20250906/sponge-mixin-0.16.4-0.8.7-1-a20250906.jar Service=Starloader Bootstrap Env=UNKNOWN
17:35:31 [main] [17:35:31.931] [INFO] de.geolykt.starloader.Starloader: Java version: 17.0.19. JavaInterop J9: true
17:35:31 [main] [17:35:31.931] [INFO] de.geolykt.starloader.Starloader: Storing log files in /var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/.
17:35:31 [main] [17:35:31.944] [INFO] de.geolykt.starloader.mod.ExtensionManager: Start loading code modifiers...
17:35:32 [main] [17:35:31.995] [INFO] d.g.starloader.launcher.service.SLMixinLogger: Compatibility level set to JAVA_11
17:35:32 [main] [17:35:31.996] [INFO] de.geolykt.starloader.mod.ExtensionManager: Found mixin in extension TestingEnvironmentExtension: micromixin-test-neo-mixins.json
17:35:32 [main] [17:35:31.996] [INFO] de.geolykt.starloader.mod.ExtensionManager: Done loading code modifiers.
17:35:32 [main] [17:35:32.057] [WARN] d.g.starloader.launcher.service.SLMixinLogger: Mixin environment was unable to detect the current side, sided mixins will not be applied
17:35:32 [main] [17:35:32.074] [INFO] de.geolykt.starloader.Starloader: From 1 prototypes, 1 extensions were loaded.
17:35:32 [main] [17:35:32.074] [INFO] de.geolykt.starloader.Starloader: Initializing extension: preinit
17:35:32 [main] [17:35:32.075] [INFO] de.geolykt.starloader.Starloader: Initializing extension: init
17:35:32 [main] [17:35:32.077] [INFO] de.geolykt.starloader.Starloader: Initialized extension TestingEnvironmentExtension.
17:35:32 [main] [17:35:32.077] [INFO] de.geolykt.starloader.Starloader: Initializing extension: postinit
17:35:32 Testing extension running with classloader TestingEnvironmentExtension
17:35:32 SLL running under CL 'jdk.internal.loader.Loader@41a4555e' (named: 'null')
17:35:32 SLL running under Module de.geolykt.starloader.launcher@4.0.0-a20250922
17:35:32 [main] [17:35:32.095] [INFO] de.geolykt.starloader.Starloader: All Extensions initialized within 21ms
17:35:32 [main] [17:35:32.097] [INFO] de.geolykt.starloader.launcher.IDELauncher: Starting main class org.stianloader.micromixin.testneo.testenv.MicromixinTestNeo with arguments [micromixin-test-config-gradle.json]
17:35:32 [main] [17:35:32.125] [INFO] o.s.m.testneo.testenv.MicromixinTestNeo: Testing environment with CL Starloader Root ClassLoader
17:35:32 [main] [17:35:32.134] [INFO] d.g.starloader.launcher.service.SLMixinLogger: Initializing MixinExtras via com.llamalad7.mixinextras.service.MixinExtrasServiceImpl(version=0.5.0).
17:35:32 [main] [17:35:32.551] [INFO] o.s.micromixin.testneo.testenv.TestReport: Summary:
17:35:32 [main] [17:35:32.570] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.InjectMixinsTarget> 6/6 members passed (12/12 constraints passed total)
17:35:32 [main] [17:35:32.571] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.LocalCaptureMixinsTarget> 11/11 members passed (23/23 constraints passed total)
17:35:32 [main] [17:35:32.571] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.OverwriteMixinsTarget> 1/1 members passed (2/2 constraints passed total)
17:35:32 [main] [17:35:32.572] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.WrapOpMixinsTarget> 13/13 members passed (31/31 constraints passed total)
17:35:32 [main] [17:35:32.573] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.WrapOpMixinsTarget$WrapOpCancellable> 14/14 members passed (35/35 constraints passed total)
17:35:33 ================================================================================
17:35:33 Following modules present: [ch.qos.logback.classic, ch.qos.logback.core, de.geolykt.starloader.launcher, de.geolykt.starloader.ras, org.fusesource.jansi, org.jetbrains.annotations, org.objectweb.asm, org.objectweb.asm.commons, org.objectweb.asm.tree, org.objectweb.asm.tree.analysis, org.objectweb.asm.util, org.slf4j, org.stianloader.micromixin.annotations, org.stianloader.micromixin.transform]
17:35:34 Following modules not initialized (you might want to define them as root modules): [org.objectweb.asm.tree, org.objectweb.asm]
17:35:34 'de.geolykt.starloader.launcher.IDELauncher' is loaded by 'null' and is of module 'de.geolykt.starloader.launcher'
17:35:34 Class URL (as per protection domain): file:/var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/.maven/org/stianloader/launcher-micromixin/4.0.0-a20260404.1/launcher-micromixin-4.0.0-a20260404.1.jar
17:35:34 [main] [17:35:34.140] [WARN] de.geolykt.starloader.launcher.IDELauncher: Extension directory undefined.
17:35:34 [main] [17:35:34.142] [INFO] de.geolykt.starloader.launcher.IDELauncher: Using prototypes from following sources:
17:35:34 [main] [17:35:34.145] [INFO] de.geolykt.starloader.launcher.IDELauncher: - [file:/var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/build/libs/micromixin-testing-suite-neo-0.9.0.jar]
17:35:34 [main] [17:35:34.163] [INFO] de.geolykt.starloader.Starloader: Java version: 17.0.19. JavaInterop J9: true
17:35:34 [main] [17:35:34.165] [INFO] de.geolykt.starloader.Starloader: Storing log files in /var/lib/jenkins/workspace/micromixin/micromixin-testing-suite-neo/.
17:35:34 [main] [17:35:34.175] [INFO] de.geolykt.starloader.mod.ExtensionManager: Start loading code modifiers...
17:35:34 [main] [17:35:34.219] [INFO] de.geolykt.starloader.mod.ExtensionManager: Found mixin in extension TestingEnvironmentExtension: micromixin-test-neo-mixins.json
17:35:34 [main] [17:35:34.221] [INFO] de.geolykt.starloader.mod.ExtensionManager: Done loading code modifiers.
17:35:34 [main] [17:35:34.225] [INFO] de.geolykt.starloader.Starloader: From 1 prototypes, 1 extensions were loaded.
17:35:34 [main] [17:35:34.226] [INFO] de.geolykt.starloader.Starloader: Initializing extension: preinit
17:35:34 [main] [17:35:34.226] [INFO] de.geolykt.starloader.Starloader: Initializing extension: init
17:35:34 [main] [17:35:34.227] [INFO] de.geolykt.starloader.Starloader: Initialized extension TestingEnvironmentExtension.
17:35:34 [main] [17:35:34.229] [INFO] de.geolykt.starloader.Starloader: Initializing extension: postinit
17:35:34 Testing extension running with classloader TestingEnvironmentExtension
17:35:34 SLL running under CL 'jdk.internal.loader.Loader@178213b' (named: 'null')
17:35:34 SLL running under Module de.geolykt.starloader.launcher@4.0.0-a20260404.1
17:35:34 [main] [17:35:34.235] [INFO] de.geolykt.starloader.Starloader: All Extensions initialized within 9ms
17:35:34 [main] [17:35:34.237] [INFO] de.geolykt.starloader.launcher.IDELauncher: Starting main class org.stianloader.micromixin.testneo.testenv.MicromixinTestNeo with arguments [micromixin-test-config-gradle.json]
17:35:34 [main] [17:35:34.254] [INFO] o.s.m.testneo.testenv.MicromixinTestNeo: Testing environment with CL Starloader Root ClassLoader
17:35:34 [main] [17:35:34.478] [ERROR] o.s.micromixin.testneo.testenv.TestReport: Member org.stianloader.micromixin.testneo.testenv.targets.InjectMixinsTarget.<clinit>/org.stianloader.micromixin.testneo.testenv.targets.InjectMixinsTarget$WrongCallbackInfoClass:()V failed constraint TRANSFORMATION_FAILURE_EXPECTED
17:35:34 [main] [17:35:34.479] [INFO] o.s.micromixin.testneo.testenv.TestReport: Summary:
17:35:34 [main] [17:35:34.480] [WARN] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.InjectMixinsTarget> 5/6 members passed (11/12 constraints passed total)
17:35:34 [main] [17:35:34.480] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.LocalCaptureMixinsTarget> 11/11 members passed (23/23 constraints passed total)
17:35:34 [main] [17:35:34.481] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.OverwriteMixinsTarget> 1/1 members passed (2/2 constraints passed total)
17:35:34 [main] [17:35:34.481] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.WrapOpMixinsTarget> 13/13 members passed (31/31 constraints passed total)
17:35:34 [main] [17:35:34.481] [INFO] o.s.micromixin.testneo.testenv.TestReport: <org.stianloader.micromixin.testneo.testenv.targets.WrapOpMixinsTarget$WrapOpCancellable> 14/14 members passed (35/35 constraints passed total)
17:35:34
17:35:34 [Incubating] Problems report is available at: file:///var/lib/jenkins/workspace/micromixin/build/reports/problems/problems-report.html
17:35:34
17:35:34 Deprecated Gradle features were used in this build, making it incompatible with Gradle 10.
17:35:34
17:35:34 You can use '--warning-mode all' to show the individual deprecation warnings and determine if they come from your own scripts or plugins.
17:35:34
17:35:34 For more on this, please refer to https://docs.gradle.org/9.5.0-rc-1/userguide/command_line_interface.html#sec:command_line_warnings in the Gradle documentation.
17:35:34
17:35:34 BUILD SUCCESSFUL in 53s
17:35:34 39 actionable tasks: 31 executed, 8 up-to-date
17:35:34 Consider enabling configuration cache to speed up this build: https://docs.gradle.org/9.5.0-rc-1/userguide/configuration_cache_enabling.html
17:35:35 Build step 'Run with timeout' changed build result to SUCCESS
17:35:35 [micromixin] $ /bin/sh -xe /tmp/jenkins5861390395763461253.sh
17:35:35 + curl http://localhost:25615/maven/commit
17:35:35 % Total % Received % Xferd Average Speed Time Time Time Current
17:35:35 Dload Upload Total Spent Left Speed
17:35:35
17:35:37 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
17:35:37 0 0 0 0 0 0 0 0 --:--:-- 0:00:01 --:--:-- 0
17:35:37 100 2 100 2 0 0 1 0 0:00:02 0:00:01 0:00:01 1
17:35:37 100 2 100 2 0 0 1 0 0:00:02 0:00:01 0:00:01 1
17:35:39 OK
17:35:39 real 0m2.046s
17:35:39 user 0m0.009s
17:35:39 sys 0m0.014s
17:35:39 ERROR: Step ‘Discord Notifier’ aborted due to exception:
17:35:39 java.lang.ClassNotFoundException: org.json.JSONObject
17:35:39 at java.base/java.net.URLClassLoader.findClass(URLClassLoader.java:445)
17:35:39 at jenkins.util.URLClassLoader2.findClass(URLClassLoader2.java:70)
17:35:39 at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:593)
17:35:39 at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:526)
17:35:39 Caused: java.lang.NoClassDefFoundError: org/json/JSONObject
17:35:39 at PluginClassLoader for discord-notifier//nz.co.jammehcow.jenkinsdiscord.DiscordWebhook.<init>(DiscordWebhook.java:62)
17:35:39 at PluginClassLoader for discord-notifier//nz.co.jammehcow.jenkinsdiscord.WebhookPublisher.perform(WebhookPublisher.java:236)
17:35:39 at hudson.tasks.BuildStepMonitor$1.perform(BuildStepMonitor.java:20)
17:35:39 at hudson.model.AbstractBuild$AbstractBuildExecution.perform(AbstractBuild.java:817)
17:35:39 at hudson.model.AbstractBuild$AbstractBuildExecution.performAllBuildSteps(AbstractBuild.java:766)
17:35:39 at hudson.model.Build$BuildExecution.cleanUp(Build.java:189)
17:35:39 at hudson.model.Run.execute(Run.java:1886)
at hudson.model.FreeStyleBuild.run(FreeStyleBuild.java:44)
at hudson.model.ResourceController.execute(ResourceController.java:97)
at hudson.model.Executor.run(Executor.java:456)
Finished: SUCCESS