Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I output from java code to the Jenkins console?

I have java code with many System.out.println() added. One of them is at the start of the "main" method. When I start the code in NetBeans, I see the console output with all these println.

When I start the class in Jenkins/ant with fork&spawn set to true (as a separate task), it runs, but no println is put to the Jenkins console.

Can I make System.out.println to write to Jenkins console?

I have found an interesting repaired Jenkins issue, they say "a variable 'out' of the object model can be used to write messages to the build console" How?

Edit: In the same project, the applications that are not spawned output their stdout into the Jenkins console OK.

Edit 2. Please, Notice that I want to output to Jenkins console, not to a file.

like image 715
Gangnus Avatar asked Oct 21 '22 07:10

Gangnus


1 Answers

If you overriding the method perform then, use BuildListener instance to get logger instance and write using print method. Like this

@Override
public boolean perform(AbstractBuild build, Launcher launcher, BuildListener listener) {

    // This is where you 'build' the project.       /
    // This also shows how you can consult the global configuration of the builder
    listener.getLogger().println("Inside the Perform Method");
    return true;
}
like image 150
Mayur Lokare Avatar answered Oct 23 '22 09:10

Mayur Lokare