git+jenkins/hudson+python构建环境

转载自:http://my.oschina.net/lanybass/blog/61397

环境准备

要能做好持续整合,首先就要先准备好 CI 服务器。这个服务器的环境,要尽可能接近上线系统的环境;这样我们在做完建置和测试并发布程序后,才能确保它在正式上线时不会出问题。

CI 服务器也需要能够执行 Java ,因为接下来提到的 CI 平台软件需要透过 Java 来执行,所以也请大家先在 CI 服务器上安装好 JDK 。

JDK安装
先下载JDK1.6 
我选择安装在/opt目录里
装好之后,添加环境变量:
vi /etc/profile
在 export PATH USER ..... 这句代码之前添加以下代码

#=================
JAVA_HOME=/opt/jdk1.6.0_27
PATH=$JAVA_HOME/bin:$PATH
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export JAVA_HOME PATH CLASSPATH
#=============

然后 source /etc/profile

还有我们也需要GIT。

CI 平台

CI 服务器最重要的角色就是 CI 平台了,两个较为有名的 CI 平台: CruiseControl 及 Hudson 。而在多方比较及网络上前辈的推荐之下,我选择了 Hudson 这个建置容易而且设定也容易的 CI 平台。

因为 Oracle 申请了 Hudson 的商标,让 Hudson 开发者决定把名称改为 Jenkins

这里提供两种安装及执行的方式:

一、透过支持 Servlet 的 Web Container 执行:

  1. 安装支持 Servlet 的 Web Container (例如 Apache Tomcat) 。
  1. 下载最新版 jenkins.war 地址:http://mirrors.jenkins-ci.org/war/latest/jenkins.war。
  1. 将 jenkins.war 放在 webapps 目录中并启动服务器。
  1. 在浏览器上开启网址 http://127.0.0.1:8080/jenkins 看到 jenkins 的起始画面时即安装成功。

二、 不使用容器,直接执行
在OPT下建立 jenkins目录,chown将目录拥有者改为当前桌面用户,将jenkins.war 放进去,然后建立一个启动脚本start.sh
vi start.sh: 写入: nohup java -jar jenkins.war --httpPort=8080 &
另其可执行: chmod 755 start.sh
然后就可以启动了: ./start.sh
关闭时:ps aux|grep java 找到当前进程 kill掉
注意:如果当前有任务正在构建中,而你不愿意等到构建结束就想kill,请先进入 系统管理->准备关机,然后再kill

启动jenkins之前请确定启动jenkins的账号能够访问远程git

初始化设置: 1.进入 “系统管理”->“系统设置”
找到 “JDK 安装” -> 新增 ->去掉 自动安装的勾 -> 别名随便(如 jdk1.6) -> java_home填你自己的

加入 Plugin 安装好 Jenkins 后,其实它并不能马上为我们工作,因为我们必须先安装一些必要的 Plugin 才行。

在「 Manage Hudson (管理 Jenkins ) 」的画面上选择「Manage Plugins (管理插件) 」,并点选「 Available (有效的) 」页签 ;接着找到以下 plugin ,勾选后按下最下方的「 Install (安装) 」。

GIT plugin
Violations
Cobertura Plugin
envinject Plugin

安装最后一个插件时,勾选 “当安装成功并且没有运行中的任务时重启Jenkins”来使插件生效

如果连接插件库失败则插件列表就是一篇空白,就只好手工下载插件然后在“高级”里面传上去安装

插件镜像地址: http://mirrors.jenkins-ci.org/plugins/  
我们上面的几个插件:
1.http://mirrors.jenkins-ci.org/plugins/git/latest/git.hpi
2.http://mirrors.jenkins-ci.org/plugins/violations/latest/violations.hpi
3.http://mirrors.jenkins-ci.org/plugins/cobertura/latest/cobertura.hpi
4.http://mirrors.jenkins-ci.org/plugins/envinject/latest/envinject.hpi

装完之后还需要装一些命令行的支持程序,注意,需要装在你的runtime的env里:

pip install coverage  //测试覆盖率检查
pip install unittest-xml-reporting    //xml测试报告
pip install nose   //测试相关
pip install pylint    //代码风格检查
pip install clonedigger //重复代码检测

编写测试用例模板
在setup.py所在目录新建 tests 目录(此处演示项目为paster创建的一个python模块,setup.py所在目录即为项目根路径)
然后参考xclubs.pubsrv项目的tests,把里面的两个py文件复制过来修改(我把代码贴在下面好了。。),把相应的模块名替换为你自己的

# -*- coding: utf-8 -*-
#文件路径tests/run.py
"""
xclubs.pubsrv unit test suite.
Usage:
    python run.py
"""

import sys, os

os.chdir(os.path.dirname(__file__))

_EXIT_FAILED = 1
_MODULE_NAME = 'xclubs.pubsrv' #xclubs.pubsrv这里要改

try:
    import nose
except ImportError:
    print ('nose is required to run the test suite')
    sys.exit(_EXIT_FAILED)

try:
    sys.path.insert(0, '..')
except ImportError:
    print ('can not find %s to test: %s' %
           (_MODULE_NAME, sys.exc_info()[1]))
    sys.exit(_EXIT_FAILED)
else:
    print ('%s test suite running (python %s)...' %
           (_MODULE_NAME, sys.version.split()[0]))

nose.main()
# -*- coding: utf-8 -*-
#文件路径tests/test_smssrv.py
import unittest
#from xclubs.pubsrv import sms #这里要改,引用你需要测试的功能,现在已经注释掉了,因为目前没有任何可加载的包

class SmsTest(unittest.TestCase):
    def setUp(self):  #初始化
        self._phone = 15000000000
        self._msg = 'test msg'

    #测试某一个具体的功能
    def test_send(self):  #测试发送短信的功能,目前没有模块,直接注释掉
        pass
        #there is no sms and send() ,so disable related line
        #self.assertEquals(sms.send(self._phone, self._msg),1)

#  测试另一个函数
#    def test_another_method(self):
#        pass
#        

其中run.py用来运行所有测试脚本的,test_smssrv.py是具体测试某一组功能的,以后新建的测试用例均以test_开头

然后把tests目录的更改push到git

新建项目
点击 “新job” ->填写项目名称->选择 “自由风格...”
“源码管理”栏目:选“git”-> Repositories填入地址,如:

git@xcgti.com:xclubs.pubsrv.git

Branches to build填入你的feature分支,如:

origin/xclubs.pubsrv_20120607_sendsms

“构建环境” 栏目: 勾选 “Inject environment variables to the build process” -> Properties Content 里加入:

PATH=/opt/pyenv/xclubs/bin:$PATH
#/opt/pyenv/xclubs/bin即为装了flask等项目依赖包和刚刚装了coverage等插件的env
#如果你没有使用virtualenv那就跳过此步骤

以下就是插件需要做的检测,由shell实现 “构建” 栏目: 增加构建步骤 ->execute shell
第一个:运行测试用例,并生成报告

#!/bin/bash
coverage run tests/run.py --with-xunit
coverage xml
echo "run unit test complete"

再添加一个:检测代码风格
其中xclubs.pubsrv 是某一个具体的包名,改为你自己的

#!/bin/bash
pylint --rcfile scripts/pylintrc -f parseable --max-line-length=120 xclubs.pubsrv > pylint.txt
echo "run pylint complete"

第三个:检测重复代码
xclubs是总的包名,改为你自己的

#!/bin/bash
clonedigger --cpd-output -o clonedigger.xml xclubs
echo "run clonedigger complete"

构建后操作
即构建之后,将检测结果导出给jenkins使用
点击 “add post-build action”->“Publish JUnit tests result report”->填入: **/tests/nosetests.xml ->勾选 “保留长的标准输出/错误”
再点击 “add post-build action” -> “Publish Cobertura Coverage Report” ->

Cobertura xml report patter 填写:**/coverage.xml
Source Encoding选择 “UTF-8”

再点击 “add post-build action” -> “Report Violations” ->

cpd栏填写:**/clonedigger.xml
pylint栏填写:**/pylint.txt
Source encoding选择:UTF-8

点击保存

点击你刚刚建的项目, 左侧点 “立即构建”
左侧的Build History里出现如下的一次构建历史
#1 2012-6-6 19:54:53
若构建结果为蓝色表示全通过,否则就有问题,具体可点进去查看“控制台输出”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值