我已经通过BlueOcean UI在本地Jenkins上创建了非常基本的Multibranch Pipeline。从默认配置中,我删除了几乎所有行为,除了发现分支的行为。配置行如下:
在Jenkinsfile
内,我尝试设置以下情形:
master
分支我的Jenkinsfile
的摘录:
pipeline {
agent none
stages {
stage('Setup') {
agent {
label "master"
}
steps {
sh "git checkout -f ${env.BRANCH_NAME}"
}
}
stage('Merge with master') {
when {
not {
branch 'master'
}
}
agent {
label "master"
}
steps {
sh 'git checkout -f origin/master'
sh "git merge --ff-only ${env.BRANCH_NAME}"
}
}
stage('Build Back-end') {
agent {
docker {
image 'openjdk:8'
}
}
steps {
sh './gradlew build'
}
}
stage ('Build Front-end') {
agent {
docker {
image 'saddeveloper/node-chromium'
}
}
steps {
dir ('./front-end') {
sh 'npm install'
sh 'npm run buildProd'
sh 'npm run testHeadless'
}
}
}
}
}
管道本身和构建步骤都可以正常工作,但是问题在于Jenkins在每个阶段之前都添加了“从版本控制中检出”步骤。该步骤查找新分支,获取引用,还签出当前分支。这是完整构建日志的相关输出:
// stage Setup
> git checkout -f f067047bbdd3a5d5f9d1f2efae274bc175829595
sh git checkout -f my-branch
// stage Merge with master
> git checkout -f f067047bbdd3a5d5f9d1f2efae274bc175829595
sh git checkout -f origin/master
sh git merge --ff-only my-branch
// stage Build Back-end
> git checkout -f f067047bbdd3a5d5f9d1f2efae274bc175829595
sh ./gradlew build
// stage Build Front-end
> git checkout -f f067047bbdd3a5d5f9d1f2efae274bc175829595
sh npm install
sh npm run buildProd
sh npm run testHeadless
因此,如您所见,它有效地将工作目录重置为在每个阶段git checkout -f f067...595
之前的特定提交。
是否有任何方法可以禁用此默认签出行为? 还是任何可行的选项,如何将这种可选合并实现到master分支?
谢谢!
答案 0 :(得分:2)
默认情况下,git scm
将在Jenkins管道中执行。您可以通过以下方式禁用它:
pipeline {
agent none
options {
skipDefaultCheckout true
}
...
此外,我建议您看看其他有用的管道选项https://jenkins.io/doc/book/pipeline/syntax/#options