IOS測試-Fastmonkey


目錄:

一、背景

二、Fastmonkey介紹

三、Fastmonkey操作前准備

四、Fastmonkey工程配置過程

五、執行Monkey測試

六、FAQ

 

Fastmonkey實踐

 


一、背景:

       因眾所周知的原因隨着Xcode從7.x升級到8.x或9.x,我們無法再使用Instrument的uiautomation腳本對iOS應用進行Monkey測試,所以我們一直期待行業測試與開發大牛產出新的Monkey開源工具,在這期間我們也使用過了一些技術大神開發的基於appium或者基於macaca的開源Monkey測試工具但是都有這樣或者那樣的問題比如:配置過於復制,上手慢,執行速度達不到要求、有的還需要進行App源碼插庄等問題,直到Faskmonkey的出現它集成了眾家之長,已經基本能滿足我們日常的iOS應用壓力測試了。

二、Fastmonkey介紹:

Fastmonkey是zhangzhao大神最近開源的一款iOS應用Monkey測試工具,基於 XCTestWD,swiftmonkey 二次開發,實現無需插樁的 iOS monkey 自動化工具 fastmonkey,優點如下:

1.無需插樁!2.高效率,每秒4-5個action!4.輕量極簡!詳細介紹請參考TesterHome鏈接 :

Faskmonkey測試工具介紹

項目開源地址:

Xcode9.x(https://github.com/zhangzhao4444/Fastmonkey

Xcode8.3.x(https://github.com/zhangzhao4444/Fastmonkey/tree/xcode8.3

三、Fastmonkey操作前准備:

注意:本文所述操作步驟都是基於Xcode8.x或者Xcode9.x的版本, 注意針對不的Xcode版本下載不同項目工程的、操作前准備:

1)Xcode8.3.x /Xcode9.x軟件;

2)iOS 第三方庫管理工具-Carthage;

3)iOS開發者證書文件;

4)Fastmonkey工程代碼從github上下載;

詳細說明:

1)Xcode8.3/Xcode9.x是用於導入Faskmonkey工程及運行monkey測試;

2)Carthage是iOS用於下載工程所依賴第三方庫的;如果沒有安裝請使用下面命令進行安裝:

brew install  carthage

3)iOS開發者證書用於工程中的構建及簽名,證書可以是團隊的開發者證書也可以是免費的個人開發者證書,如何申請個人開發者證書請大家參考其他文檔此處不再敖述。

4)工程代碼直接從https://github.com/zhangzhao4444/Fastmonkey下載

 

四、Fastmonkey工程配置過程

配置是經過我們驗證過了,不過因為每一個人的手機與Xcode版本問題可能會一些差異,大家也可以參考TesterHome上的fastmonkey 自我掃盲貼

Fastmonkey的掃盲帖子

1.解壓下載后的Fastmonkey-xxx.zip的文件,打開終端進入解壓后的子目錄XCTestWD-master

 
進入解壓后的子目錄XCTestWD-master

2.執行下列步驟下載工程所依賴的包 :

1)修改目錄中的Cartfile文件,將github "SwiftyJSON/SwiftyJSON" 改為github "SwiftyJSON/SwiftyJSON"  ==  3.1.4   修改github "tadija/AEXML"為github "tadija/AEXML" == 4.1.0如下圖:

 

 
修改目錄中的Cartfile文件

2)下載工程所依賴的包

$  carthage update

PS:如果此步驟出現錯誤請參考后面的FAQ

 
下載工程所依賴的包,可能需要一些時間具體要依賴於您的網絡速度,請耐心等待完成

 

3.配置XCTestWD項目工程:

雙擊子目錄XCTestWD中的XCTestWD.xcodeproj文件打開項目工程

 

 
 

 

1)修改Product ID,團隊開發者證書需要修改,個人免費開發者證書可跳過此步驟

a. 修改XCTestWD所需要的產品ID如com.xxxx.XCTestWD.XCTestWD

 

 
xxx為證書所定義的產品ID前綴一般是公司或者企業的域名

 

b.修改XCTestWDUITests所需要的產品ID如com.xxx.XCTestWD.XCTestWD

 

 
xxx為證書所定義的產品ID前綴一般是公司或者企業的域名

 

2)修改簽名賬號(個人開發Team與團隊證書設置是不一樣的):

a1.團隊開發者證書如下圖:

 
a1.修改XCTestWD Code Signing為相應的賬號
 
a1.修改XCTestWD Code Signing為相應的Team賬號

 

a2.同a1過程修改XCTestWDUITests的Code Signing賬號

 

b.個人開發者證書如下圖:

b1.修改XCTestWDUITests的Code Signing賬號

 
 

b2.同b1修改XCTestWD的Code Signing賬號

 

3)添加XCTestWDMonkey.swfit到Server目錄

 

 
右鍵點擊server目錄,然選擇"Add Files to "XCTestWD"

 

 
選擇【XCTestWDMonkey.swift】文件添加到Server

 

4)清空XCTestWD的Objective-C Bridging Header選項中的值

 
清空Objective-C Bridging Header選項中的值
 
清空Objective-C Bridging Header選項

4.修改XCTestWD項目工程代碼中的配置值:

1)修改運行模式,將XCTestWDRunner.swift文件中的serverMode設置為false如下圖

 
修改此項為false后,這樣Monkey就可以直接從Xcode中運行,不需要再使用額外的命令了

2)修改XCTestWDMonkey.swift文件中的bundleID為被測App的值的如下圖:

 
改為自己App的實際BundleID,如何查找被測App的BundleID請百度一下這里不再敖述

2)修改Monkey.swift文件中的elapsedTime值確定你需要運行多長時間的Monkey,注意單位是秒,如下圖:

 

 
修改Monkey執行時長

五、執行Monkey測試

1)選擇要執行的手機與Target注意App事先安裝到被測試手機上,手機已經插入Mac電腦USB接口

 
從下拉列表中選擇XCTestWDUITests與手機

2)開始執行Monkey

 

 
選擇【Product】--【Test】執行Monkey測試

六、FAQ:

1. 如果carthage update的時候如果報這個錯xcrun: error: unable to find utility "xcodebuild", not a developer tool or in PATH需要在Xcode中 Preferences > Locations里設置Command Line Tools為自己使用版本的Xcode --謝謝光暈_9c54的提醒

2.如果是Xcode9.x可能會出現XCTestWDApplication.h file not found錯誤如下圖,請按照下面方法解決:

 

 
XCTestWDApplication.h file not found錯誤

添加XCTestWDApplication.h與XCTestWDApplication.m文件到PrivateHeaders目錄,如下圖

 

 
選中PrivateHeaders然后點擊右鍵在彈出的界面中選擇【Add Files to "XCTestWD"...】項目
 
選擇XCTestWDApplication.h與XCTestWDApplication.m然后點擊Add
 
XCTestWDApplication.h與XCTestWDApplication.m被添加到了PrivateHeaders中

2.第一次執行時可能會報錯,因為需要在手機上信任你的個人證書或者團隊證書,第二次執行就不會了。一般位於手機【設置】--【通用】--【描述文件】中

3.每次運行完成后,在Xcode的Debug Ouput框中會輸出相應的日志與截圖保存位置,每次運行完成后日志會報錯,這個錯誤是由於Fastmonkey的Bug,參加下面Issue鏈接,主要原因是當執行時長一到時,Monkey測試自行停止,這個停止是強退的,但Xctest沒有正常退出造成的,目前還沒有找到好的解決方法。

https://github.com/zhangzhao4444/Fastmonkey/issues/12

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM