Jenkins管道在对HashMap排序时用新值'-1'替换变量

时间:2019-04-04 08:46:34

标签: groovy jenkins-pipeline jenkins-groovy

首先,我创建一个Map并用值填充它。然后,我想按值对地图进行排序。我使用示例中的sort方法。 在控制台的IDE中,我看到程序的行为符合我的期望。

但是,当我从groovy管道运行程序时,排序后发生了莫名其妙的事情。由于输入方式灵活,地图会替换为数字。

node("Linux_Default") {
    Map painters = ["Rubens": 1, "Bosch": 2, "Repin": 5, "DaVinci": 10] as HashMap<String, Integer>
    println('unordered')
    for (String i : painters) {
        println('* ' + i)
    }

    def sortedPainters = painters.sort(){ a, b -> b.value <=> a.value }
    try {
        println('ordered')
        for (String i : sortedPainters) {
            println('* ' + i)
        }
    } catch (Exception e) {
        println(e.toString())
    }
}

IDE的输出

unordered
* Rubens=1
* Bosch=2
* Repin=5
* DaVinci=10
ordered
* DaVinci=10
* Repin=5
* Bosch=2
* Rubens=1

管道控制台的输出

Running in Durability level: PERFORMANCE_OPTIMIZED
Running on jenkins-agent-linux-008 in /u01/jenkins_slave/workspace/KMD/maps_sort_test
unordered
* Rubens=1
* Bosch=2
* Repin=5
* DaVinci=10
ordered
* -1
Finished: SUCCESS

1 个答案:

答案 0 :(得分:1)

在Jenkins中,使用自定义闭包的某些方法在CPS下处理得不好。解决方案是在@NonCPS闭包中隔离有问题的代码,例如:

@NonCPS
def getSorted(def map) {
    map.sort(){ a, b -> b.value <=> a.value }
}

然后您会看到def sortedPainters = getSorted(painters)返回一个排序的映射,而不是一个奇怪的标量。

另请参阅:

Jenkins sort method behaviour not as expected

pipeline groovy script - Sort a list with custom comparator or closure not sorting