すべてのジョブを取得し、名前を正規表現と比較し、一致する場合はジョブのビルドをトリガーするビルド フロー プラグインを使用してジェンキンス フローを構築しています。
私はこれを完全に機能させています:
import jenkins.model.Jenkins
import java.util.regex.*
Pattern myRegex = ~/release_status.*/
for (item in jenkins.model.Jenkins.instance.items)
{
if (item.name ==~ myRegex) {
build( "$item.name" )
}
}
ただし、一致するすべてのジョブを構築するには非常に長い時間がかかります (現在は 20 ありますが、さらに多くのジョブが存在する可能性があります)。
これを各ジョブを並行して実行しようとしていますが、グルーヴィーな構文がわかりません。
私は3つの異なる方法を試しました:
import jenkins.model.Jenkins
import java.util.regex.*
Pattern myRegex = ~/release_status.*/
parallel (
{
for (item in jenkins.model.Jenkins.instance.items)
{
if (item.name ==~ myRegex) {
build( "$item.name" )
}
}
}
)
^^これはまだ機能しますが、以前と同じように機能します。一度に 1 つのジョブが実行され、前のジョブが完了するまで次のジョブはビルドされません。
import jenkins.model.Jenkins
import java.util.regex.*
Pattern myRegex = ~/release_status.*/
parallel (
{
for (item in jenkins.model.Jenkins.instance.items)
{
if (item.name ==~ myRegex) {
{ build( "$item.name" ) },
}
}
}
)
^^このエラー
Script1.groovy: 9: Ambiguous expression could be either a parameterless closure expression or an isolated open code block;
solution: Add an explicit closure parameter list, e.g. {it -> ...}, or force it to be treated as an open block by giving it a label, e.g. L:{...} @ line 9, column 9.
{ build( "$item.name" ) },
壊す
import jenkins.model.Jenkins
import java.util.regex.*
Pattern myRegex = ~/release_status.*/
parallel (
[
for (item in jenkins.model.Jenkins.instance.items)
{
if (item.name ==~ myRegex) {
useless: { build( "$item.name" ) },
}
}
]
)
壊す
import jenkins.model.Jenkins
import java.util.regex.*
Pattern myRegex = ~/release_status.*/
parallel (
for (item in jenkins.model.Jenkins.instance.items)
{
if (item.name ==~ myRegex) {
{ build( "$item.name" ) },
}
}
)
上記の両方のブロックで次のエラーが発生します。
org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:
Script1.groovy: 5: unexpected token: for @ line 5, column 5.
for (item in jenkins.model.Jenkins.instance.items)
ここには多くのコードがありますが、かなり単純です。周りを見回しても、Groovy に関する優れたリソースはあまり見つかりません。