57.Python项目在Jenkins中的自动化测试实践

  • requirments
  • 介绍
  • 准备测试结果数据
    • nosetestsxml
    • coveragexml
    • pylintout
  • 准备Gitlab侧API token
  • 在Jenkins上添加对应API token的Credential
  • 配置Jenkins项目
  • 配置Gitlab的webhook

转载请注明原始链接:http://blog.csdn.net/a464057216/article/details/52934077

requirments

  • OS: Ubuntu 14.04+
  • Gitlab 8.1 +
  • Jenkins 2.19.0 +

介绍

在Jenkins上对Github项目或者Gitlab项目做自动化构建的初级配置方法可以参考自动化工具Jenkins安装配置入门。在Ubuntu上搭建Gitlab服务器的方法也可以参考我之前的博文。

使用Jenkins对Python项目进行自动化测试主要依赖nose(单元测试)、pylint(语法检查)、coverage(代码覆盖率)等工具,配合插件在Jenkins的Web界面展示测试结果。如果使用Gitlab托管代码,本文也涵盖了Jenkins与Gitlab配合的配置方法,最终效果如下:

1.代码改动push到Gitlab自动触发Jenkins构建项目,执行自动化测试。
2.测试包括基本功能测试、覆盖率分析、语法检查等,所有的测试结果在Jenkins上展示,包括测试通过率分析(可以具体到每个用例的通过情况)、测试覆盖率可以具体到每一行、语法检查可以具体到每一行的错误细节。
3.如果测试成功,Jenkins新建一个Tag提交到Gitlab项目中,同时生成一个供下载的zip包。
4.Jenkins界面包含项目代码行数分析。
5.在Gitlab项目的commits列表中看到可以每一次CI的结果,点击build-id后会跳转到Jenkins界面查看构建信息。在Jenkins中点击相应的commit-hash会跳转到Gitlab对应提交的diff页面。

准备测试结果数据

项目代码行数分析依赖sloccount这个工具,首先在Jenkins服务器上安装它:

# Written by: CSDN - Mars Loo的博客
sudo apt-get update
sudo apt-get install sloccount

在构建中增加构建步骤,选择Execute shell
57.Python项目在Jenkins中的自动化测试实践_第1张图片

在其中填写如下内容(其中mypackage是被测试的package的名字):

# Written by: CSDN - Mars Loo的博客
virtualenv --no-site-packages env
. env/bin/activate
pip install --quiet nosexcover
pip install --quiet pylint
nosetests --with-xcoverage --with-xunit --cover-package=mypackage --cover-erase
pylint -f parseable mypackage/ | tee pylint.out
sloccount --duplicates --details mypackage > sloccount.sc
tar --exclude *pyc -zcf mypackage.tar.gz mypackage 

nosetests.xml

--with-xunit选项会生成nosetests.xml文件,在构建后操作中勾选Publish JUnit test result report即可显示该部分的内容:
57.Python项目在Jenkins中的自动化测试实践_第2张图片

在构建结果的Test Result页面可以看到测试结果(点击进入可以看到结果详情):
57.Python项目在Jenkins中的自动化测试实践_第3张图片

coverage.xml

--with-xcoverage选项会生成coverage.xml文件,安装Cobertura Plugin后可以在构建后操作中勾选Publish Cobertura Coverage Report填写相关信息:
57.Python项目在Jenkins中的自动化测试实践_第4张图片

构建完成后,在构建信息的Cobertura Coverage Report页面,可以看到测试覆盖率变化的趋势,和具体到每个文件的覆盖情况:
57.Python项目在Jenkins中的自动化测试实践_第5张图片

pylint.out

pylint生成的语法检查报告pylint.out需要配合Violations plugin插件使用,然后在构建后操作中勾选Report Violations,找到pylint的配置并填写:
57.Python项目在Jenkins中的自动化测试实践_第6张图片

构建后在构建记录中即可以看到具体到文件每一行的语法检查结果:
57.Python项目在Jenkins中的自动化测试实践_第7张图片

准备Gitlab侧API token

在个人信息的Account界面生成Private token:
57.Python项目在Jenkins中的自动化测试实践_第8张图片

在Jenkins上添加对应API token的Credential

Credentials管理界面添加该API token:
57.Python项目在Jenkins中的自动化测试实践_第9张图片
然后在Jenkins系统设置的Gitlab部分填写相关信息(使用刚才添加的API token,可以点击Test Connection测试配置是否OK):
57.Python项目在Jenkins中的自动化测试实践_第10张图片

配置Jenkins项目

在Jenkins的自由风格的软件项目中设置如下内容:
57.Python项目在Jenkins中的自动化测试实践_第11张图片

虽然使用的是Gitlab,但是在Github project中配置相关信息之后,可以在构建记录中点击commit-id直接跳转到Gitlab的diff页面:
57.Python项目在Jenkins中的自动化测试实践_第12张图片

上面的GitLab Repository Name主要配合Gitlab logo插件使用,先在Jenkins的系统设置中设置GitLab Account Setting(使用之前在Gitlab上生成的API token):
这里写图片描述

填写项目在Gitlab的Project URL后,在Jenkins的项目列表中可以显示项目在Gitlab上的图标:
57.Python项目在Jenkins中的自动化测试实践_第13张图片

继续配置自由项目的源码管理部分,这里使用的Credentials是Jenkins服务器访问Gitlab使用的私钥信息而不是之前配置的APi token,Refspec中的信息为:

+refs/heads/*:refs/remotes/origin/* +refs/merge-requests/*/head:refs/remotes/origin/merge-requests/*

57.Python项目在Jenkins中的自动化测试实践_第14张图片

构建触发器配置如下:
57.Python项目在Jenkins中的自动化测试实践_第15张图片

这里没有选择Poll SCM的方式,如果选择这种方式的话,为了提高Jenkins的响应速度,通产会设置较短的轮询周期比如1分钟,这样Jenkins上面项目过多的话对Gitlab的API访问频率太高。

为了将Jenkins的每次构建信息发布到Gitlab,需要在构建后的操作步骤中添加Publish build status to Gitlab Commit
57.Python项目在Jenkins中的自动化测试实践_第16张图片

如果构建成功,Jenkins提交新建的Tag到Gitlab时,需要使用的SSH私钥有可写权限,然而Gitlab的deploy key是没有写权限的,所以要在Gitlab中添加对应公钥到用户信息的SSH Keys信息中使其具有写权限,然后在Jenkins的构建后的操作步骤中添加Git Publisher
57.Python项目在Jenkins中的自动化测试实践_第17张图片

上面配置中的Target remote name应该与源码管理->git->Repositories中的name信息一致。

在Jenkins的构建后的操作中添加Public SLOCCount analysis results(需要先安装SLOCCount Plug-in插件):
这里写图片描述
然后在Jenkins的构建记录页面可以看到项目代码行数的变化趋势及各个语言的代码行数变化:
57.Python项目在Jenkins中的自动化测试实践_第18张图片
57.Python项目在Jenkins中的自动化测试实践_第19张图片

Jenkins的构建后的操作步骤中添加Archive the artifacts
57.Python项目在Jenkins中的自动化测试实践_第20张图片
把这个步骤放在构建后的操作步骤中的最后,然后在每次成功构建后会生成一个下载链接供下载包:
57.Python项目在Jenkins中的自动化测试实践_第21张图片

配置Gitlab的webhook

在Gitlab的对应项目上配置webhook,trigger的URL是Jenkins页面中GitLab CI Service URL后面给出的URL,勾选Push eventsMerge Request events等自己需要的条件,如果Jenkins没有https支持,去勾选Enable SSL verification,然后点击Add Webhook,点击Test按钮尝试触发Jenkins构建即可。

至此使用Jenkins对Python项目进行自动化测试的搭建已经全部完成。如果对Gitlab上的项目的master分支有修改的话,Jenkins会立即触发构建(下图中的第29次构建,当然也可以在Jenkins的Web管理界面手工触发构建如第30次构建):
57.Python项目在Jenkins中的自动化测试实践_第22张图片

构建完成后构建结果会同步到Gitlab中(点击对应的对号或者差号后再新的页面点击对应的build id会跳转到Jenkins的构建信息页面):
57.Python项目在Jenkins中的自动化测试实践_第23张图片
对于成功的构建,Jenkins会自动新建一个Tag并提交到Gitlab:
57.Python项目在Jenkins中的自动化测试实践_第24张图片

如果觉得我的文章对您有帮助,欢迎关注我(CSDN:Mars Loo的博客)或者为这篇文章点赞,谢谢!

你可能感兴趣的:(研发工具)