51Testing软件测试论坛

标题: Jenkins 2.7 pipeline 功能使用介绍 [打印本页]

作者: 八戒你干嘛    时间: 2017-6-22 14:59
标题: Jenkins 2.7 pipeline 功能使用介绍
安装现在的jenkins版本+pipeline插件
pipeline这是jenkins2.0的核心特性. 也是最适合持续交付的feature.
与以往的通过Web交互来配置流程不同, Jenkins也走向了正规的工程化交付方式即使用配置文件. 这本身也印证了行业的经验everything is code
这样就再也不用每个项目都手工配置或者搞各种恶心的项目模板了.
jenkins的pipeline主要是通过一个配置文件或者job里面的pipeline配置来设定每个job的步骤.
pipeline定义了几乎所有要用到的流程, 比如执行shell, 存档, 生成测试报告, 发布报告等.

持续交付 as codehttps://jenkins.io/doc/book/pipeline-as-code/
  1. node(‘linux’){
  2.   git url: 'https://github.com/jglick/simple-maven-project-with-tests.git'
  3.   def mvnHome = tool 'M3'
  4.   env.PATH = "${mvnHome}/bin:${env.PATH}"
  5.   sh 'mvn -B clean verify'
  6. }

  7. 举一个sonar的例子

  8. node {
  9.     stage "auth"
  10.     sshagent(['xxxx-xxxx-xxx-xxxx-xxxx']){
  11.        stage 'Checkout'
  12.        git url: 'git@git.tonghuashun.com:tonghuashun/tonghuashun-income.git'
  13.     }
  14.    stage 'Build'
  15.    sh "mvn clean install -Dmaven.test.skip=true"
  16.    stage "Sonar"
  17.    sh "mvn sonar:sonar"

  18. }
复制代码


建议是在每个项目里面让研发放一个Jenkinsfile, jenkins的其他插件可以自动读取这些配置批量导入已有的项目.
pipeline-syntax这是一个Jenkinsfile的命令查询工具. 辅助新手编写持续交付的配置指令. 非常好用.


分析测试结果
  1. node {
  2.    git url: 'https://github.com/joe_user/simple-maven-project-with-tests.git'
  3.    def mvnHome = tool 'M3'
  4.    sh "${mvnHome}/bin/mvn -B -Dmaven.test.failure.ignore verify"
  5.    step([$class: 'ArtifactArchiver', artifacts: '**/target/*.jar', fingerprint: true])
  6.    step([$class: 'JUnitResultArchiver', testResults: '**/target/surefire-reports/TEST-*.xml'])
  7. }
复制代码



作者: 悠悠小仙仙    时间: 2017-6-22 15:07
这是一个和web配置并行的配置方式?相较于web上配置有什么优势呢
作者: 八戒你干嘛    时间: 2017-6-22 15:08
悠悠小仙仙 发表于 2017-6-22 15:07
这是一个和web配置并行的配置方式?相较于web上配置有什么优势呢

如果类比的话, 可以理解为 是从 Maven -> Gradle的改进. Jenkinsfile本身是个groovy脚本. 跟gradle很像. 这样就可以做便捷的做各种判断和循环处理了. 有了统一的Jenkinsfile以后批量的导入项目到Jenkins也方便了.
作者: 51IT测试    时间: 2019-1-7 15:37
Jenkins Pipeline可以发布C#中的DEbug版本的代码么、




欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2