好吧,标题写得好长.
言归正传,本文主要是讲述如何使用这些工具来整合流程,实现 Android 平台的自动化测试.
首先说下背景,因为我测试的东西面向多个国家,对于不同的地域可能有不同的功能,对应不一样的发行渠道,需要测试工具有便捷的 case 管理功能,能方便地面对不同的发行渠道选择不同的 case.而 TestNG 可以很方便地配置这些,所以选择这个框架.
这里直接使用 Appium 源码中自带的 testng 项目示例.位置在源码目录中的

/sample-code/examples/java/testng

1.改造 Report 的呈现方式
示例 Project 用 Maven 来组织项目,所以这里就不改项目架构了,喜欢 ant 的同学自己去实践吧.
因为示例中用的是 TestNG 自己生成的测试报告,比较难看,这里用 ReportNG 来美化一下.
编辑 pom.xml,在依赖中添加 ReportNG 的依赖:

<dependency>
    <groupId>org.uncommons</groupId>
    <artifactId>reportng</artifactId>
    <version>1.1.4</version>
    <scope>test</scope>
    <exclusions>
        <exclusion>
            <groupId>org.testng</groupId>
            <artifactId>testng</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>com.google.inject</groupId>
    <artifactId>guice</artifactId>
    <version>3.0</version>
    <scope>test</scope>
</dependency>

ReportNG 还得注册一下监听器,这个放在 testng.xml 中去注册,就不写在 POM 里了.maven-surefire-plugin 插件里配置一个参数,用于接收不同的 testng.xml

    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-surefire-plugin</artifactId>
        <version>2.17</version>
        <configuration>
        <suiteXmlFiles>
            <suiteXmlFile>res/${xmlFileName}</suiteXmlFile>
        </suiteXmlFiles>
</configuration>
    </plugin>

pom 里面的值留空:

<properties>
    <xmlFileName></xmlFileName>
</properties>

2.使用不同的 testng.xml 配置文件来配置不同的渠道测试 case
在项目根目录建个 res 文件夹,把 testng.xml 放进去,testng.xml 文件内容如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite
    name="Suite"
    verbose="1" >
    <test name="Project_V3023" >
        <packages>
            <package name="com.saucelabs.appium" />
        </packages>
    </test>
    <listeners>
        <listener class-name="org.uncommons.reportng.HTMLReporter" />
        <listener class-name="org.uncommons.reportng.JUnitXMLReporter" />
    </listeners>
    <usedefaultlisteners name="false" />
</suite>

这个文件用来配置选择不同的渠道需要选择的 case,res 文件夹下可以扔很多 testng.xml 文件用于不同的渠道.比如 A 渠道可以用 testng1.xml,B 渠道可以用 testng2.xml,另外在这里面注册一下 ReportNG 的监听器.
最后修改一下 Project 的项目文件结构,最后变成这个样子 (为了演示方便,只保留了一个测试类):

3.配置 Jenkins
勾选参数化构建,创建 2 个参数
第 1 个参数是创建一个文件夹,并且返回文件夹路径,这个在后面发邮件要用到.

第 2 个参数是返回 testng.xml 的名字,这里因为我只有一个,所以直接返回了,后面这里面可以自己加条件判断是返回哪个 testng.xml 的名字.比如 1\3\5 跑 testng1.xml,2\4\6 跑 testng2.xml

用 SVN 来管理测试代码

构建触发器使用定时触发方式,不截图了.

使用 Maven 构建项目,并且接收一个参数

构建后运行一下 Python 的脚本,用途是拷贝文件,将生成的 ReportNG 报告拷贝到上面由参数 1 创建的目录下.而这个目录同时也是 Apache 的网站目录,这样就可以直接通过 URL 看到测试报告了.

最后用邮件插件发一下邮件,我这里都是引用的系统配置里的内容

收到的邮件是这个样子

点开链接,看到测试报告

最后,总结一下
用 SVN 管理管理代码,Jenkins 做持续集成,项目组织用 Maven,测试框架用 Appium+TestNG,报告呈现用 ReportNG.
好吧,撇去 Appium 不谈,其他都是大家用来用去的东西了.
现在的问题:
1.Jenkins 的触发方式现在是每天晚上定时触发,因为我拿不到源码,开发的编译系统用的也不是 Jenkins,我不知道要如何才能更好地使用持续集成.各位小伙伴的持续集成又是怎么做的呢?
2.选择 testng.xml 不够灵活,不能根据项目特征自动选择对应的 testng.xml,比如我想拿渠道号来区分,可 Jenkins 怎么拿到渠道号?
3.Appium 支持多个设备同时运行吗?之前用 Robotium 时使用 Spoon 就可以同时在多个设备上运行.

扩展一下:
网易上个月出了一个 TestNG 的小插件,实现了失败用例重跑,失败自动截图,展示用例运行次数等等功能,很好很实用,就只有一个缺点,生成的报告是改造了 TestNG 自带的 emailable-report.html,实在是太 - 丑-了~~这个看能不能把功能移植到 ReportNG 上去.有兴趣的小伙伴可以关注.
项目地址:https://github.com/NetEase/arrow


↙↙↙阅读原文可查看相关链接,并与作者交流