Как мне пометить текущий набор изменений git из Jenkinsfile?
Я хочу пометить текущий набор изменений git и вставить метку из файла Jenkinsfile. Если тег уже существует, его необходимо заменить.
Я хочу использовать эту логику, чтобы пометить сборку, которая прошла с snapshot
тег, который будет мобильным тегом.
Как я могу это сделать?
5 ответов
Вот способ, которым я смог реализовать это таким образом, но если вы знаете лучший способ, я более чем готов это услышать.
#!groovy
stage 'build'
node {
repositoryCommiterEmail = 'ci@example.com'
repositoryCommiterUsername = 'examle.com'
checkout scm
sh "echo done"
if (env.BRANCH_NAME == 'master') {
stage 'tagging'
sh("git config user.email ${repositoryCommiterEmail}")
sh("git config user.name '${repositoryCommiterUsername}'")
sh "git remote set-url origin git@github.com:..."
// deletes current snapshot tag
sh "git tag -d snapshot || true"
// tags current changeset
sh "git tag -a snapshot -m \"passed CI\""
// deletes tag on remote in order not to fail pushing the new one
sh "git push origin :refs/tags/snapshot"
// pushes the tags
sh "git push --tags"
}
}
Для людей, которые не могли заставить работать выше, я использовал плагин sshagent напрямую, что и помогло:
stage('tag build'){
checkout([
$class: 'GitSCM', branches: [[name: '*/master']],
userRemoteConfigs: [[credentialsId: 'git',
url: 'ssh://<ssh URL>']],
extensions: [[$class: 'RelativeTargetDirectory', relativeTargetDir: 'targeted-dir']]
])
sshagent(credentials: ['<credentials ID.']){
dir('targeted-dir'){
sh("git config user.email '<email>")
sh("git config user.name '<user>.com'")
// deletes current snapshot tag
sh ("git tag -d ${PARAM_VERSION_NUMBER} || true")
// tags current changeset
sh ("git tag -a ${PARAM_VERSION_NUMBER} -m \"versioning ${PARAM_VERSION_NUMBER}\"")
// deletes tag on remote in order not to fail pushing the new one
sh ("git push origin :refs/tags/snapshot")
// pushes the tags
sh ("git push --tags")
}
}
}
Я хочу поделиться своими настройками Jenkins Pipeline и моим решением публиковать изменения / теги для git repo через SSH (пока Git Publish Support находится в стадии разработки). Пожалуйста, проверьте это для получения дополнительной информации, любые идеи по улучшению приветствуются.
Короче просто добавь файл git_push_ssh.groovy
в ваш проект и вызов метода pushSSH()
из Jenkinsfile вот так:
env.BRANCH_NAME = "mycoolbranch"// BRANCH_NAME is predefined in multibranch pipeline job
env.J_GIT_CONFIG = "true"
env.J_USERNAME = "Jenkins CI"
env.J_EMAIL = "jenkins-ci@example.com"
env.J_CREDS_IDS = '02aa92ec-593e-4a90-ac85-3f43a06cfae3' // Use credentials id from Jenkins
def gitLib = load "git_push_ssh.groovy"
...
gitLib.pushSSH(commitMsg: "Jenkins build #${env.BUILD_NUMBER}", tagName: "build-${env.BUILD_NUMBER}", files: "changelog.txt someotherfile.txt");
Подход на основе SSH-агента не работал на нашем сервере сборки Windows, однако мы по-прежнему хотели использовать учетные данные, хранящиеся в диспетчере учетных данных Jenkins. Поскольку наши учетные данные Git являются ключом SSH, мы поняли, что можем позволить Jenkins предоставить нам ключевой файл напрямую:
stage("Tag") {
steps {
script {
def tagName = "..."
withCredentials([sshUserPrivateKey(credentialsId: "idOfYourCredentials", keyFileVariable: "KEY")]) {
def key = KEY.replaceAll("\\\\", "/") // Only needed on Windows
env.GIT_SSH_COMMAND = "ssh -i ${key}"
bat "git tag \"${tagName}\""
bat "git push --tags"
}
}
}
}
Чтобы это работало для голубого океана (который использует соединение https), используйте следующее:
sshagent(credentials: ["406ef572-9598-45ee-8d39-9c9a227a9227"]) {
def repository = "git@" + env.GIT_URL.replaceFirst(".+://", "").replaceFirst("/", ":")
sh("git remote set-url origin $repository")
sh("git tag --force build-${env.BRANCH_NAME}")
sh("git push --force origin build-${env.BRANCH_NAME}")
}