如何使用Jenkins运行,测试和终止HTTP服务器?

All*_*lan 9 jenkins

我正在建立一个正在构建RESTful HTTP服务的团队.我们在设置Jenkins CI作业时遇到问题,该作业将构建服务,在后台运行,执行一些测试,然后终止服务器.

细节

  • 服务器使用hapi框架在Node.js中构建,并且有一些用mocha编写的单元测试.
  • 测试是使用Maven用Java编写的.(为什么不进行基于node.js的测试?因为我们的测试部门已经投入时间来创建基于Java的REST测试框架.)
  • 如果基于节点的单元测试失败或者java测试失败,则构建应该失败.
  • 我们的Jenkins盒子由公司其他地方的支持团队运营; 我们的构建在Linux从属上执行.

目前的尝试

我们现在有一些类似的工作,但它不可靠.我们使用3个构建步骤:

第一个构建步骤是Execute Shell使用以下命令的步骤:

npm install
npm test
node server.js ./test-config.json &
Run Code Online (Sandbox Code Playgroud)

其次,我们做了一个Invoke Maven 3指向测试的步骤pom.xml.

第三,我们开始Invoke Standalone Sonar Analysis进行静态代码分析.

这主要是有效的,但是我们依靠Jenkins的ProcessTreeKiller来在作业完成后停止服务.我们总是收到警告:Process leaked file descriptors. See http://wiki.jenkins-ci.org/display/JENKINS/Spawning+processes+from+buildfor more information

不幸的是,我们有过这样的情况:服务很快终止(在测试完成之前)或服务根本没有终止(导致后续构建失败,因为端口已经在使用中).

所以我们需要更可靠的东西.

尝试失败

我们尝试设置一个shell脚本,它处理启动服务,运行maven,终止服务,然后输出退出代码.但是这没有用,因为mvn命令行上没有命令.我们的Jenkins有多个maven版本(也是jdks),我不知道他们住在奴隶的哪个地方,或者如何在不使用Invoke Maven 3构建步骤的情况下使用它们.

思路

我们已经玩弄了一些想法来解决这个问题,但希望得到其他可能解决Jenkins类似问题的指导.

  1. 一段时间后服务会自行终止.问题在于弄清楚让他们跑多久.
  2. 完成后添加构建步骤以终止服务.问题是如果maven执行失败,后续步骤将不会运行.(如果我们告诉maven忽略测试失败,那么如果构建失败,则构建不会显示为已损坏.)
  3. 尝试删除任何现有的服务进程作为构建的第一步和最后一步.问题是其他团队也使用这些Jenkins从属设备,因此我们需要确保在完成构建时终止服务.
  4. 通过Maven开始和停止node.js服务做类似博客的建议.问题是我们不知道Jenkins是否会将生成的后台任务识别为"泄漏的文件描述符"并在我们完成测试之前将其终止.

如果Jenkins有一个"Post-build action"可以让你运行一个清理脚本,那就太好了.或者,如果它有一个"执行后台进程"构建步骤,它会在构建结束时终止后台项目.但我找不到那样的东西.

有没有人设法让Jenkins像这样远程做任何事情?

Sla*_*lav 3

一些头脑风暴:

  • 您可以全局或每次调用关闭 Jenkins ProcessTreeKiller。我不知道为什么这不适合你。

  • 针对#2,有几个选项:

    1. 无论构建步骤是否失败,都会执行构建后操作。这将是触发“服务清理”任务的好方法,该任务无论构建状态如何都会运行。
    2. 您可以使用任何构建步骤插件将任何构建步骤设置为构建后操作,也可以使用构建后任务插件,后者甚至提供了定义触发条件的选项。
  • 您可以使用文本查找器插件根据正则表达式标准更改构建状态

  • 您可以设置条件构建步骤。“条件”甚至可能是某些脚本执行的结果