利用Hudson持续集成来执行Android自动化测试
据我了解,方便的方法大致有两个:其一,利用Hudson(或Jenkins)持续集成系统;其二、利用Testin或东软易测云等第三方云测试平台达成。
本文以Hudson在Windows系统的环境搭建为例。
一、安装篇
1、安装JDK,推荐1.6版本
这个一般做Android的开发、测试都会装了,但要注意配好环境变量,即将jdk的bin目录加到Path里,将jdk目录加入JAVA_HOME
2、安装ant
http://ant.apache.org/bindownload.cgi,解压到本地合适目录,如D:\apache-ant-1.8.4
3、安装tomcat
http://tomcat.apache.org/download-70.cgi,解压到本地适当目录,如D:\apache-tomcat-7.0.30
4、安装hudson
http://java.net/projects/hudson/downloads/directory/war,将下载到的war包更名为 hudson.war(这个名字关系到访问的URL地址,也可以是别的),拷贝到tomcat的\webapps目录下,如D:\apache- tomcat-7.0.30\webapps
至此,只要启动tomcat/bin/startup.bat,就可以在浏览器里用http://127.0.0.1:8080/hudson对hudson服务进行访问了。
二、配置篇
打开hudson配置界面(主页 - 系统管理 - 系统设置)
1、配置好JDK,名称任意,JAVA_HOME填准确。
2、配置好ANT,名称任意,ANT_HOME填准确。
3、拉到最下面,邮件通知部分,SMTP、用户默认邮件后缀、系统管理员邮件都按照公司实际情况配好,Hudson URL填成http://本机IP:8080/hudson/,这样同局域网内的其他用户就可以访问你配置的Hudson服务了。
同时点开Advanced,勾选"使用SMTP",使用你在公司域内的邮箱地址和密码,SMTP端口一般选择默认的25,Charset填写"UTF-8",这样测试结果才会以你的邮箱发出给相关人。
打开hudson插件界面(主页 - 系统管理 - 管理插件 - 可选插件)
搜索以下几个插件并安装:
1、Hudson Subversion Plug-in,顾名思义,SVN插件。
2、JUnit Attachments Plugin,junit测试报告附件插件。
3、Android Emulator Plugin,如果要用Android模拟器来测试的话,这个是要装上的。
4、Hudson GIT plugin,如果团队是用Git来同步代码的话,那这个也装上。
5、Email-ext plugin,邮件发送定制插件。Hudson默认只在构建失败(或从失败转向成功)后发送提醒邮件;使用这个插件可以定制发送邮件的不同情景。
其它都按需安装喽。
新建任务 - 主项目(被测项目)打包任务
1、构建一个自由风格的项目,名称合适取。
2、Source Code Management部分,选Subversion,Repository URL里面填写你主体项目的SVN地址,其它选默认就行了。
3、Build trigger部分,勾选Build periodically可以使版本定时构建,语法和Unix的crontab一样。勾选Poll SCM则是定期去SVN或CVS的workspace去检查,如果有更新更构建。
4、Build Environment部分,如果是用模拟器来测试的话,就勾选"Run an Android emulator during build"。
5、Build部分,最关键的部分来了。
Ant version:选Default就行;
Targets:要应用的ant target名称,也可以是名称列表(多个名称用空格分隔),如果什么都不写的话,就是build脚本中的默认那个任务;
Build File:有时候我们未必用ant默认找的build.xml来编译,那就用这个选项来自定义脚本路径和名称,如build4test.xml;
Properties:这里用来写build脚本运行时需要的一些参数。其效果等同于在项目的workspace下建一个ant.properties 文件,然后在build脚本里加入<property file="ant.properties" />。其实说起来肯定是后一种方法更灵活,但有时为了安全起见(比如不把key.store.password泄漏出去),就把这些属性写在 Hudson服务端。(事实上这些属性都记录在该项目的config.xml里)
这个部分肯定是要和项目的build脚本结合起来的,所以build脚本的编写也是关键的地方。Ant脚本的内涵很深,用的好的话它可以完成的 事情超乎你想象,有必要下工夫研究一下。这里Google已经帮咱们写好了一个功能很强大的build脚本,如果没有特殊的定制需求,我们可以直接引用它 里面的target。这个脚本是在Android_SDK目录/tools/ant/下的build.xml,里面有三个很重要的 target:debug, release, install。
debug是用debug key打包,速度相对较快,测试时建议选用。release是用release key打包,速度齁慢,发布版本时必然打的是release包。另外测试时打release包还有个好处是利于和已发布版本的包进行覆盖安装。 install顾名思义很容易理解,但前提是debug或release任务已经得到应用。因为我们要构建包用于自动化测试,所以这里建议用的 target组合是debug install,即在上面说的Targets部分填入"debug install"。
用"android update project -p 项目路径"命令可以帮你在project目录下建立一个build.xml,当然你完全可以根据项目的需要自己定制Build脚本,要引用Google现 成target的关键是在build脚本里加入这样一句话:
<import file="${sdk.dir}/tools/ant/build.xml" /> |
当然sdk.dir这个property需要提前定义好。
6、构建完成后操作:因为主项目构建完成后需要启动测试项目的构建,所以在Build other projects里面填写测试项目(如果还没建好就等建好了回头再来填)
其它的像Publish JUnit test result report和E-mail Notification等选项都要在测试项目中定义,所以这里就不勾选了。
新建任务 - 测试项目打包与执行任务
1、1-4步基本是相通的,不再赘述。
2、第5步,用ant完成debug install后,因为要执行测试,所以我们需要定义一个用于测试的任务。可以用类似下面的代码:
<target name="gotest" depends="stormtestinstall"> <echo message="Start Testing======================================="/> <exec executable="adb" failonerror="true"> <arg value="shell"/> <arg value="am"/> <arg value="instrument"/> <arg value="-w"/> <arg value="-e"/> <arg value="class"/> <arg value="com.storm.smart.athtest._AllTestSuite"/> <arg value="com.storm.smart.test/pl.polidea.instrumentation.PolideaInstrumentationTestRunner"/> </exec> <echo message="End Testing=========================================="/> </target> |
这样的话我们可以在Targets输入框填入debug install gotest,即先打debug包,再安装,再执行测试。
3、测试完成后,我们需要把测试报告从手机里拷贝出来,这里用一个bat来完成:点击"Add build step",选择"Excute Windows batch command",在输入框内填入(pull-test-result.bat)。这个bat的内容类似下面这样:
adb root adb shell mount -o remount rw / adb pull /data/data/com.storm.smart/files/com.storm.smart.athtest-TEST.xml |
4、构建完成后操作:首先我们需要把拿到的xml初始报告文件格式化成友好的格式,然后将结果邮件通知给相关人员。
对应地,勾选"Publish Junit test result report"项,在Test report XMLs里填入*-TEST.xml;勾选"E-mail Notification",填入相关人邮箱,按需勾选子选项即可。
至此,整个配置告一段落。