【发布时间】:2020-03-10 17:58:31
【问题描述】:
我有几个测试项目(API 测试、UI Selenium 测试等),它们测试同一个应用程序。现在,应用程序的步骤。部署在每个 jenkins 文件中都有重复。
目标是有一个通用的app-deployment作业,在服务器上准备应用程序:
- 从特定版本或标签中获取;
- 定义各种环境变量,如许可证等;
- 生成 WAR 文件;
- 将它们复制到 Tomcat 构建目录;
- 启动 Tomcat 并等待上下文准备就绪。
在此之后我不能只是完成构建,因为 Jenkins 会杀死所有创建的进程,包括启动的 Tomcat。我为 Tomcat 尝试了doNoKillMe cookie,但这导致了与重新启动应用程序和数据库连接相关的其他几个问题。所以,当应用准备就绪时,我将input 步骤与 ID 放在一起:
node {
properties([
parameters([
string(name: 'REVISION',
defaultValue: '',
),
string(name: 'TAG_NAME',
defaultValue: ''),
]),
])
withEnv(buildEnvVariables()) {
stage('Checkout') {
}
stage('Prepare file system') {
}
stage('Prepare database') {
}
stage('Builds WAR files') {
}
stage('Tomcat deploy') {
// Delete previous WAR files from Tomcat
// Copy generated files to tomcat
sh "$TOMCAT_DIR/bin/startup.sh"
waitForTokenFileOrFail()
}
input(id: 'IsBuilt', 'Application is ready... ')
}
}
现在,我希望从其他几个 特定于测试的 jenkins 文件调用此作业:
node {
properties([
parameters([
string(name: 'TESTS_SUITE',
defaultValue: '',
),
string(name: 'OTHER_PARAM',
defaultValue: ''),
]),
])
withEnv(buildEnvVariables()) {
stage('Checkout') {
}
stage('Stop any running application builds') {
def jenkinsQueue = Jenkins.instance.queue
jenkinsQueue.items.findAll { it.task.name.startsWith(contextDeployBuildName) }.each {
echo "Found pending $contextDeployBuildName job. Cancelling: ${it.getId()}"
jenkinsQueue.doCancelItem(it.getId())
}
Jenkins.instance.getItemByFullName(contextDeployBuildName)
.getAllJobs().first().getBuilds()
?.each { build ->
if (build.isBuilding()) {
try {
echo "Found running $contextDeployBuildName job. Stopping: ${build.number}"
httpRequest(
httpMode: 'POST',
authentication: 'credentialsID',
url: "${JENKINS_URL}job/$contextDeployBuildName/${build.number}/stop")
} catch (any) {
println any.message
}
}
}
}
stage('Build the app') {
build(wait: true, job: contextDeployBuildName, parameters: [
string(name: 'REVISION', value: env.BRANCH_NAME),
string(name: 'TAG_NAME', value: env.TAG_NAME)])
// How to wait for a specific input/condition here???
}
stage('Run tests') {
}
stage('Report, cleanup') {
}
}
}
我正在使用带有wait 条件的jenkins build step,但它似乎只能等待工作完成。更改部署作业的状态被忽略(我相信,因为没有触发构建侦听器):
currentBuild.rawBuild.@result = hudson.model.Result.SUCCESS
问题:
如何正确地通知 testing-specific 作业关于 app-deployment 作业中的触发输入?是否有解决此类“部署测试”问题的标准方法?
目前,除了管道工具,我有两种丑陋的方法来检查状态:
- 等待 Tomcat/应用程序文件夹中的某些特定文件
- 当触发具有指定 ID 的输入时,可以通过该 ID 访问它的页面,因此我可以 ping 输入的页面,直到它返回 200 状态而不是 404。
【问题讨论】:
-
你能在你的问题中添加一些代码吗?
-
为什么不使用一个管道来构建、部署、测试然后停止?
-
这就是我现在拥有的:清理系统、生成 WAR、复制到 tomcat、部署、测试等。问题是我至少有 3 个不同的测试项目实际上使用相同的应用程序语境。所以很多步骤都是重复的。
标签: tomcat jenkins continuous-integration jenkins-pipeline cloudbees