1. 程式人生 > >Appium自動化測試框架研究(2)——搭建IOS環境

Appium自動化測試框架研究(2)——搭建IOS環境

 

  今天的文章講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中啟動Ap