andrewkro
andrewkro

Reputation: 23

Groovy Postbuild in Jenkins, parsing the log for strings and counting them

I am new to Groovy and am trying to set up a postbuild in Jenkins that allows me to count strings and determine if the build succeeded by how many the count returns at the end.

Here is my example code :

class Main {

  def manager = binding.getVariable("manager")
  def log = manager.build.logFile.text
  def list = log
  def JobCount = list.count {it.startsWith("====") && it.contains("COMPLETE")}
  if (JobCount == 7) {
      manager.listener.logger.println("All Jobs Completed Successfully")
  } else {
      manager.addWarningBadge("Not All Jobs Have Completed Successfully")
      manager.buildUnstable()  
  }
}

I am looking for a specific string that gets printed to the console when the test has completed successfully. The string is "====JOB COMPLETE====" and I should have 7 instances of this string if all 7 tests passed correctly.

Currently when I run this code I get the following error :

Script1.groovy: 6: unexpected token: if @ line 6, column 5.
   if (JobCount == 7)
   ^

Any help would be greatly appreciated

Upvotes: 2

Views: 9975

Answers (3)

Ori Dar
Ori Dar

Reputation: 19000

manager.build.logFile.text returns the whole file text as String.

What you need is readLines():

def list = manager.build.logFile.readLines()
def JobCount = list.count {it.startsWith("====") && it.contains("COMPLETE")}

and of course as mentioned below, the Jenkins Groovy Postbuild plugin runs Groovy scripts, so you will have get rid of the enclosing class declaration (Main)

Upvotes: 4

thecodesmith_
thecodesmith_

Reputation: 1312

You have statements directly inside your class, without being in a method, which is not allowed in Java/Groovy. Since this is Groovy, you can run this as a script without the class at all, or put the offending code (the if statement) inside a method and call the method.

Upvotes: 2

Stanton
Stanton

Reputation: 495

Perhaps you're missing a closing }

def JobCount = list.count {it.startsWith("====") && it.contains("COMPLETE")}

Upvotes: 0

Related Questions