Получить все журналы изменений со времени последней успешной сборки в Jenkins Pipeline

11

В моем конвейере Jenkins я могу получить логи изменений текущей сборки.

def changeLogSets = currentBuild.changeSets

Есть ли способ получить все журналы изменений со времени последней успешной сборки?

пчелка
источник

Ответы:

9

Вы можете попробовать что-то вроде этого:

node('my_kubernetes_pod') {
    passedBuilds = []

    lastSuccessfulBuild(passedBuilds, currentBuild);

    def changeLog = getChangeLog(passedBuilds)
    echo "changeLog ${changeLog}"
}

def lastSuccessfulBuild(passedBuilds, build) {
    if ((build != null) && (build.result != 'SUCCESS')) {
        passedBuilds.add(build)
        lastSuccessfulBuild(passedBuilds, build.getPreviousBuild())
    }
}

@NonCPS
def getChangeLog(passedBuilds) {
    def log = ""
    for (int x = 0; x < passedBuilds.size(); x++) {
        def currentBuild = passedBuilds[x];
        def changeLogSets = currentBuild.rawBuild.changeSets
        for (int i = 0; i < changeLogSets.size(); i++) {
            def entries = changeLogSets[i].items
            for (int j = 0; j < entries.length; j++) {
                def entry = entries[j]
                log += "* ${entry.msg} by ${entry.author} \n"
            }
        }
    }
    return log;
}

Кроме того, вы можете попробовать «Плагин изменений с последнего успеха»: https://wiki.jenkins.io/display/JENKINS/Changes+Since+Last+Success+Plugin

Но это не будет работать вместе с конвейером, это отдельный подход.

user54
источник
Похоже, это решение предоставляет журналы изменений последних успешных сборок. На самом деле я искал журналы изменений (последних неудачных сборок) с момента последней успешной сборки. Но ваш ответ определенно полезен. Build.getpreviousebuuld () и рекурсия - это то, что я пропустил. Большое спасибо за ответ.
Пчела
1
Всегда добро пожаловать ;-)
user54
Я подозреваю, что рекурсивное решение может столкнуться с проблемами, выходящими за пределы стека, если у вас было много сборок. Хотя было бы не сложно переключиться на итеративный процесс.
17
1

Как я обнаружил, может быть, это поможет вам. При этом вы можете получить последний успешный файл журнала изменений сборки любой сборки проекта с Jenkins.

$DirectoryA = "D:\Jenkins\jobs\projectName\builds"  ####Jenkind directory
$firstfolder = Get-ChildItem -Path $DirectoryA | Where-Object {$_.PSIsContainer} | Sort-Object LastWriteTime -Descending | Select-Object -First 1
$DirectoryB = $DirectoryA + "\" + $firstfolder

$sVnLoGfIle = $DirectoryB + "\" + "changelog.xml" 

write-host $sVnLoGfIle
Ашу
источник