【翻譯】Appium 的故障排查

Appium 的故障排查

當你在使用過程中遇到了問題,先別急著到 github 上提交反饋,或者到 appium-discuss discussion group 提問。可以先試試在本文中能否找到解決的辦法。

常見問題

  • 確保你是跟著 README 中的每一步來做。
  • 確保你的系統已經配置好所需環境(例如. Xcode 已更至最新,Android SDK 已經安裝好,而且ANDROID_HOME也設置無誤)。
  • 確保你應用的存放路徑是正確的。
  • 在 windows 上運行 appium.app 要使用管理員權限,假如你在 cmd 中運行,也得確保是在管理員權限下。

如果你是通過 Appium.app 運行

  • 升級應用并重啟。如果你被告知應用無法升級,請到 appium.io 重新下載。

如果你是通過 Appium 的源碼運行

  • 通過 git pull 命令拉取代碼,確保當前的代碼是最新的

  • 移除舊的依賴:rm -rf node_modules

  • 重新安裝依賴:npm install

  • 代碼 Re-transpile: gulp transpile

  • 你可以使用 Appium Doctor 去檢測 Appium 環境是否已經配置好了。

  • 如果你升級到 Android SDK 22 后出現如下報錯:
    {ANDROID_HOME}/tools/ant/uibuild.xml:155: SDK does not have any Build Tools installed.
    在 Android SDK 22 中,platform 與 build tools 分別被拆分到各自的 SDK 管理包中去了。你需要確保已經正確安裝了 build-tools 與 platform-tools。

Android

  • 確保 Android 模擬器已經開啟并在運行中。
  • 出現設備連接問題時, adb kill-server && adb devices 這行命令非常有用。它可以重置你的 Android 設備的連接。
  • 確保你已經設置了 ANDROID_HOME 已經指向了 Android SDK 路徑

Windows

  • 確保已經開啟了開發者模式。
  • 確保 command prompt 已經是管理員權限。
  • 檢查 Appium 服務器正在監聽的 URL 是否與你測試腳本中的 URL 匹配的上。

IOS

  • 確保 Instruments.app 沒有被開啟。

  • 如果你使用模擬器時,記得不要讓真機連上你的電腦。

  • 確保在手機的設置中的 accessibility 輔助功能是關閉的。

  • 確保應用是變異在當前運行的模擬器上。

  • 確保應用已編譯在合適的模擬器(或真機)上(例如. 在模擬器上運行需要 debug 模式的包),否則你會出現posix spawn報錯。

  • 如果你曾經用 sudo 運行過 Appium,你可能需要運行 sudo rm /tmp/instruments_sock 該命令,而且記住以后盡量別帶上 sudo。

  • 如果你是第一次運行 Appium,記得對 Instruments 進行授權。 查閱 running on OSX documentation 了解更多。

  • 如果在真機上運行 Instruments 出現了崩潰("exited with code 253"),確保 Xcode 已經下載了設備的符號文件。到 Window -> Devices,然后他就會自動的開始下載。每次 iOS 版本升級后都需要做這步。

  • 如果你看到 iOS Simulator failed to install the application. 這樣的報錯,并且確定路徑沒有設置錯誤的話,那你可以嘗試去重啟你的電腦。

  • 確保你的 macOS 上的 keychain 已經保存了用于構建你的應用的證書,并且 WebDeriverAgent 是已簽名的。特別是你在使用 ssh 的情況下。通常失敗的話會顯示簽名報錯。

  • 如果你的應用中還有自定義的元素,他們或許不能通過默認的方式去使用 UIAutomaion(and therefore Appuim)進行自動化。你需要將 accessibility status 設置為'enabled'。在代碼中設置的方式如下:

    [myCustomView setAccessibilityEnabled:YES];
    
  • 在 iOS 上測試可能會出現類似內存泄露(包括性能不佳、程序掛起)的狀況。如果你出現了類似的問題,這很可能是由于一個 NSLog 的已知問題所導致的。其中的一個解決辦法就是將所有的 NSLog 代碼移除。然而,還是有一些巧妙的處理方法,可以不重構就能解決。

    解決辦法 1

    NSLog 是一個宏且可以被定義的。例如:

    // *You'll need to define TEST or TEST2 and then recompile.*
    
    #ifdef TEST
      #define NSLog(...) _BlackHoleTestLogger(__VA_ARGS__);
    #endif // TEST
    #ifdef TEST2
      #define NSLog(...) _StdoutTestLogger(__VA_ARGS__);
    #endif // TEST2
    
    void _BlackHoleTestLogger(NSString *format, ...) {
        //
    }
    
    void _StdoutTestLogger(NSString *format, ...) {
        va_list argumentList;
        va_start(argumentList, format);
        NSMutableString * message = [[NSMutableString alloc] initWithFormat:format
                                                    arguments:argumentList];
    
        printf(message);
    
        va_end(argumentList);
        [message release];
    }
    

    解決辦法 2

    手動去替換掉 NSLog 封裝的底層功能。該方法被 Apple in a similar context. 所推薦

    extern void _NSSetLogCStringFunction(void(*)(const char *, unsigned, BOOL));
    
    static void _GarbageFreeLogCString(const char *message, unsigned length, BOOL withSyslogBanner) {
       fprintf(stderr, "%s\\n", message);
    }
    
    int main (int argc, const char *argv[]) {
       NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
       int exitCode;
    
       setbuf(stderr, NULL);
    
       _NSSetLogCStringFunction(_GarbageFreeLogCString);
       exitCode = WOApplicationMain(@"Application", argc, argv);
       [pool release];
       return exitCode;
    }
    


### Webview/Hybrid/Safari 應用的支持

* 確保真機上的 'Web Inspector' 為打開狀態。
* 確保你已經打開 Safari 的開發者模式(Safari - Advance Preferences- Developer menu for simulators)。
* 確保你客戶端的庫提供的 appium 命令 `context` 可以讓你正確地切換 contexts。
* 當你嘗試打開代理的時候,出現了這個報錯:select_port() failed,請查閱該[文檔](https://groups.google.com/forum/#!topic/appium-discuss/tw2GaSN8WX0)。
* 在 Safari session 中,如果日志記錄到不能輸入初始 url 的問題,先確保你的軟鍵盤是否已被開啟,詳情請查閱該[文檔](https://github.com/appium/appium/issues/6440)。

### 到社區尋求幫助

如果上述步驟還沒解決你的問題,那你可以通過以下方式獲得幫助:

當你在使用 Appium 的過程中有任何問題,而且 Appium 提供的報錯信息不夠清晰的話,歡迎加入[討論組](https://discuss.appium.io)與大家進行討論。提問時請附帶上如下信息:

* 你是通過什么方式運行 Appium(Appium.app, npm, source)。
* 你使用什么操作系統。
* 你是針對什么設備和版本去做測試的(例如. Android 4.4, 或者 iOS 7.1)。
* 你是使用真機還是模擬器去做測試。
* 提供客戶端和服務端給出的的錯誤(例如. “在運行我的 Python 測試腳本時候出現了異常,Appium 服務器的報錯信息如鏈接中所示”)。
* 除了上述,在提問的時候希望可以附帶上 Appium 服務器輸出的內容(特別是在 verbose 模式下),這樣我們就可以更好地分析并跟進問題。

如果你確信你發現的是一個 bug,請直接到 [issue tracker](https://github.com/appium/appium/issues) 去提交一個 issue 去描述 bug 的信息以及重現步驟。

### 已知問題

* 如果你已在官網下載并安裝 Node,你需要使用 sudo 去運行 `npm`。可這么做這并不理想。可以嘗試通過 [nvm](https://github.com/creationix/nvm), [n](https://github.com/visionmedia/n) 或者 `brew install node` 這幾種方式去安裝!
* 通過設置代理,iOS 真機可以支持 Webview 了,詳情可查看[討論](https://groups.google.com/d/msg/appium-discuss/u1ropm4OEbY/uJ3y422a5_kJ)。
* 有時候 iOS 的 UI 元素在被定位到后的幾毫秒間會失效,這會導致一個類似 `(null) cannot be tapped` 的報錯。唯一的解決辦法就是把  finding-and-clicking 的代碼放進一個 retry block 中。
* 如果你是通過 MacPorts 去安裝 Node 與 npm,Appium 可能很難找到可執行的 `node`。你必須確保 MacoPorts 的 bin 文件夾(默認是 `/opt/local/bin`)已經添加到你的 `~/.profile`, `~/.bash_profile` 或者 `~/.bashrc` 中的 `PATH` 環境變量中。

### 特定的錯誤

|Action|Error|Resolution|
|------|-----|----------|
|Running ios test|`[INST STDERR] posix spawn failure; aborting launch`|你的應用沒有分別對應模擬器或者真機去編譯對應版本.|
|Running mobile safari test|`error: Could not prepare mobile safari with version '7.1'`|你可能需要再次運行授權的腳本以確保 iOS SDK 文件是可寫狀態。詳情請查閱 [running on OSX documentation](./running-on-osx.md#authorizing-ios-on-the-computer)|
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,443評論 6 532
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,530評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,407評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,981評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,759評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,204評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,263評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,415評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,955評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,650評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,892評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,675評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,967評論 2 374

推薦閱讀更多精彩內容