上一篇主要介紹了jenkins:真機換成模擬器,我們將真機換成模擬器,使得操作更簡單,進一步完善安卓UI自動化持續(xù)集成的自動化。其實做到這里,基本的基于orange的安卓UI自動化工程已經(jīng)建立完備了,完全可以實現(xiàn)線上監(jiān)控APP的UI層面的穩(wěn)定性情況。如果我們不想只是檢測已發(fā)布的apk的穩(wěn)定性,而是想在開發(fā)過程中實時編譯、打包成apk進行UI層面的監(jiān)控的話,就需要進行本章的進階jenkins設(shè)置了。
關(guān)于安卓UI自動化學習,我的學習路線是這樣安排的:
(一)本地:能夠獨立完成一個UI自動化工程的建立
(二)本地:命令行執(zhí)行UI自動化測試用例
(三)本地:ant打包測試工程apk+執(zhí)行UI自動化用例一體化
(四)jenkins:持續(xù)集成平臺成功構(gòu)建UI自動化工程
(五)jenkins:真機換成模擬器
(六)jenkins:持續(xù)集成平臺實現(xiàn)被測apk自動打包編譯+自動化一體化
(七)UI自動化用例編寫語法和規(guī)范
本章內(nèi)容就是第六部分,jenkins:持續(xù)集成平臺實現(xiàn)被測apk自動打包編譯+自動化一體化
一、設(shè)置環(huán)境變量
我們這里使用ant打包,在jenkins的job配置里,選擇構(gòu)建的選項為Execute Shell,命令框里首先輸入對jenkins環(huán)境變量的設(shè)置。設(shè)置ant運行地址并加入path,設(shè)置android-sdk安裝地址并將tools和platform-tools都加入path。
二、拉取被測APP代碼并打包
設(shè)置好環(huán)境變量后,我們就需要從代碼倉庫(SVN或者Git)把開發(fā)的代碼拉取下來并進行打包。
除了配置環(huán)境變量的幾句指令,關(guān)鍵的指令及其分析如下:
(1)svn co的命令就是從svn地址上把被測試APP的開發(fā)代碼拉取下來。
(2)接下來的cd命令主要是打開本job所在的本地目錄。這里注意windows系統(tǒng)的目錄表達方式是用\\分割。通常情況下job的默認存放目錄是C:\Users\hzsuixiang.jenkins\workspace\YourJobName目錄下,但是這里我設(shè)置job存放路徑為E盤自己的路徑下。如何設(shè)置job存放路徑,可參考教程。
(3)接下來看起來簡單的ant指令其實執(zhí)行了復(fù)雜的打包過程。只不過所有的任務(wù)都在build.xml中組織好了。在執(zhí)行dx命令,將class文件轉(zhuǎn)換成.dex文件時,產(chǎn)生了class.dex和classes2.dex兩個文件,還要有一步將classes2.dex文件打到apk里。
(4)最后的aapt命令就是將classes2.dex文件打到apk里。
三、拉取測試工程代碼并執(zhí)行
關(guān)鍵的指令及其分析如下:
(1)svn co的命令就是從svn地址上把被測試工程的代碼拉取下來。
(2)接下來的兩個cp命令是用被測APP打包時產(chǎn)生的R.java文件和apk文件替換到我們UI工程里。
(3)最后在UI工程目錄下執(zhí)行ant命令執(zhí)行UI自動化測試腳本。
好了,至此為止,我們就能夠?qū)崟r地將開發(fā)代碼編譯打包并執(zhí)行UI自動化測試了。
四、打包時遇到的問題分析
因為之前被測APP在開發(fā)那邊都是用gradle進行打包的,在對被測APP進行ant打包時遇到了包括編譯、分包等的若干問題,總結(jié)一下:
1.編譯時報錯
編譯時出現(xiàn)的問題首先考慮自己使用的jdk版本是否與開發(fā)環(huán)境相同,根據(jù)報錯信息,我的jenkins上指定的jdk版本是1.8,而開發(fā)環(huán)境使用1.7。于是將Jenkins默認的jdk版本改為1.7,編譯通過。
2.release時報錯
release時報錯apkbuild.bat文件找不到。首先在build.xml文件中找到release的target,確認使用到的執(zhí)行參數(shù)是什么。
我們看到執(zhí)行的是${apk-builder}這一參數(shù)。然后再在build.xml中找出apk-builder參數(shù)的設(shè)置,查看其真正執(zhí)行的腳本文件位置。
而${android-tools}參數(shù)在之前設(shè)置為本地sdk\tools的路徑,也就是D:\AppData\Local\Android\sdk\tools(注:這是我的本地sdk路徑)。打開這一路徑,發(fā)現(xiàn)其中真的沒有apkbuilder.bat文件,也難怪打包時報錯了。sdk更新3.0以后apkbuilder.bat已經(jīng)被刪除了,要想順利地執(zhí)行ant打包,可以自己重寫一個apkbuilder.bat工具,我是從網(wǎng)上下載了apkbuilder.bat放在D:\AppData\Local\Android\sdk\tools路徑下:
這下執(zhí)行應(yīng)該沒有問題了~
DUANG~報錯 “java找不到....”
問題查找了好久,終于確定問題是出在自己的java文件夾命名上了,我的java文件夾命名為java 1.7,就是這個空格成為了找不到j(luò)ava無法順利進行release的關(guān)鍵原因。這應(yīng)該也是個小小的坑了,建議以后建立文件夾少寫空格中文等這類字符,出錯的時候感覺整個世界都不好了~