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