com.lesfurets.jenkins.unit.RegressionTestHelper.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jenkins-pipeline-unit Show documentation
Show all versions of jenkins-pipeline-unit Show documentation
Jenkins Pipeline Unit testing framework
package com.lesfurets.jenkins.unit
import static com.lesfurets.jenkins.unit.MethodCall.callArgsToString
import static org.assertj.core.api.Assertions.assertThat
import static org.assertj.core.api.Assertions.fail
import java.util.function.Function
import java.util.stream.Collectors
import org.assertj.core.api.SoftAssertions
class RegressionTestHelper {
public static final String ARGUMENT_MISMATCH = """Method arguments does not match for method '%s' on '%s':
A : %s
B : %s
"""
public static final String METHOD_CALL_COUNT = """Method call '%s' does not have the same number of calls" +
expected: %d, actual %d."""
public static final String METHOD_CALL_NOT_EXISTS = "Method call '%s' does not exist on second stack"
static void testNonRegression(PipelineTestHelper helper, String targetFileName, boolean writeReference) {
targetFileName += '.txt'
def referenceFile = new File(targetFileName)
if (writeReference) {
println "Saving stack into $targetFileName"
referenceFile.withWriter { out ->
helper.callStack.each {
out.println(it)
}
}
fail('Please disable the write before commiting')
}
String callStack = helper.callStack.join('\n') + '\n'
assertThat(callStack.normalize()).isEqualTo(referenceFile.text.normalize())
}
/**
* For all method calls in stack a, there is a corresponding method call in stack b
* @param aCallStack call stack a
* @param bCallStack call stack b
*/
static SoftAssertions compareCallStack(List aCallStack, List bCallStack) {
Map> aSignatureToCall = groupBySignature(aCallStack)
Map> bSignatureToCall = groupBySignature(bCallStack)
SoftAssertions softly = new SoftAssertions()
aSignatureToCall.entrySet().stream()
.filter { e -> e.key.name != "run" }
.filter { e -> e.key.name != "load" }
.forEach { e ->
// Strict check method call exists
assertThat(bSignatureToCall)
.overridingErrorMessage(METHOD_CALL_NOT_EXISTS, e.key)
.containsKey(e.key)
// Strict check method call count
assertThat(e.value.args)
.overridingErrorMessage(METHOD_CALL_COUNT,
e.key,
e.value.args.size(),
bSignatureToCall.get(e.key).size())
.hasSameSizeAs(bSignatureToCall.get(e.key))
// Softly check method call argument values
e.value.eachWithIndex { aCall, i ->
MethodCall bCall = bSignatureToCall.get(e.key).get(i)
softly.assertThat(argsToNormalizedString(aCall) == argsToNormalizedString(bCall))
.overridingErrorMessage(ARGUMENT_MISMATCH,
aCall.methodName,
aCall.target,
aCall.args.toArrayString(),
bCall.args.toArrayString())
.isTrue()
}
}
return softly
}
private static String argsToNormalizedString(MethodCall c) {
callArgsToString(c).replaceAll(" +", " ")
}
private static Map> groupBySignature(List aCallStack) {
return aCallStack.stream().collect(Collectors.groupingBy((Function) { MethodCall c -> c.toSignature() }))
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy