今天的文章講iOS的Appium環境搭建。
對於iOS而言,只能在Mac筆記本上安裝Appium,以及所需要的各種組件。
也許有人會問,能否在Windows系統上使用Appium測試iOS手機,這不就不用花錢買Mac了嗎?答案是不可以,因為Appium的本質是把我們編寫的自動化測試腳本,翻譯成Mac中UIAutomator的腳本,所以只能Mac來做,Windows系統搞不定。但是,你可以裝黑蘋果來解決這個問題。
我們這篇文章不提黑蘋果,而是介紹怎么在mac筆記本上安裝能運行iOS自動化測試的appium。
以下的6個步驟,在上一篇文章我們已經介紹過,請參考上一篇文章。。
1)安裝Node。
2)使用Node下載Appium Server。
3)下載並安裝Appium Desktop.
4)下載並安裝Python 3。
5)使用pip下載Appium Client。
6)安裝Appium Doctor。
為什么說iOS支持Appium麻煩呢,因為還要執行下列的步驟:
1)安裝最新版的XCode,去App Store下載並安裝最新版即可
要確保XCode的版本和IPhone的版本是兼容的,否則就升級系統。
2)安裝Xcode Command Line Tools
到官網下載Command Line Tools,這哥們之前是和XCode捆在一起安裝的,后來分家單過了,所以要去Developer Apple官網單獨下載並安裝,下載地址是:
https://developer.apple.com/download/more/
不要嘗試使用xcode-select ––install,會失敗的。
3)安裝homebrew,用於mac系統的軟件包下載。執行以下腳本:
/usr/bin/ruby -e "$(curl –fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
4)安裝carthage,用於依賴管理,執行以下命令:
brew install carthage
5)安裝 libimobiledevice,用於Appium連接iOS的設備
brew install libimobiledevice –HEAD –g
6)安裝ideviceinstaller,用於管理安裝在手機上的App:
brew install ideviceinstaller –g
如果執行這個命令報錯,如下所示:
Could not connect to lockdownd. Exiting.
解決辦法就是,增加lockdown的權限,執行下面的命令即可:
sudo chmod –R 777 /var/db/lockdown
7)安裝ios-deploy,iOS10以上的系統才需要安裝
npm install -g ios-deploy
8)設置WebDriverAgent項目的Signing
Appium對iOS的支持,是通過WebDriverAgent來實現的,這是Facebook開源的一個項目,內置在Appium Desktop中,位於下面的路徑:
/Application/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-xcuitest-driver/WebDriverAgent/WebDriverAgent.xcodeproj
但是我們安裝了Appium后,並不能指定它內置的WebDriverAgent的開發者賬號,因此要進入這個目錄,手動進行設置。
用XCode打開WebDriverAgent.xcodeproj,然后配置兩個Targets,一個是WebDriverAgentLib,另一個是WebDriverAgentRunner,配置Signing,設置Team為開發者賬號即可。
9)此外,我還遇到過錯誤信息,說是Apple Developer開發者賬號需要有了新協議,需要我登陸上去點擊同意,照它說的去做,登錄到Apple Developer點擊同意就好了。
至此,在Appium上就可以運行iOS的自動化測試了,上述步驟缺一不可。可以說九九八十一難,一步一個坑,我為此整整折騰了三四天,才配置好。
10)如果前面的功課都做完了,那appium基本就可以使用了。在執行appium-doctor命令時,會看到一些警告:
我們來逐一解決這些警告。
1.opencv4nodejs cannot be found
到官網下載CMake並安裝,地址如下所示:
https://cmake.org/download/
把CMake的路徑添加到全局變量PATH中,如下所示:
export CMAKE_ROOT=/Applications/CMake.app/Contents/bin/
export PATH=$CMAKE_ROOT:$PATH
最后執行命令:
npm install opencv4nodejs
2. ffmpeg cannot be found
解決方案:輸入brew install ffmpeg
3. mjpeg-comsumer cannot be found
解決方案:輸入npm i -g mjpeg-consumer
4. idb and idb_companion are not installed
執行以下命令
brew tap facebook/fb
brew install idb-companion
pip3.7 install fb-idb
注意pip3.7是我的python的版本號。可以去全局變量中檢查一下是否設置了pip的路徑,有的是3.6或別的版本。
5. applesimutils cannot be found
執行以下命令:
brew tap wix/brew
brew install applesimutils
6. bundletool.jar cannot be found
到https://github.com/google/bundletool/releases下載bundletool.jar的最新版本,下載到的這個jar的文件名可能有帶版本號,無論是什么,都改名為bundletool.jar。
在前面創建的sdk目錄下,創建一個子目錄bundle-tool,把bundletool.jar放在這個子目錄下。
給這個子目錄和這個jar文件,增加權限。執行下面的腳本:
chmod +x
chmod +x bundletool.jar
在全局變量PATH中,增加bundletool.jar的路徑,如下所示:
expert PATH=${PATH}:$ANDROID_HOME/bundle-tool
在下一篇文章中,我將介紹電腦如何連接Android和iOS真機和模擬器,以及准備合適的DesiredCapabilities,從而在Appium中啟動App。