您好,登錄后才能下訂單哦!
原文:http://houlianpi.github.io/blog/appium-chinese-input.html
在使用Appium做手機端的自動化測試時,你可以會遇到輸入中文的問題。但是由于Appium是三個自動化測試工具的集合,所以遇到的中文問題也可能會比較難說清楚。Appium支持iOS、Android和FireFoxOS三種操作系統。但是FireFoxOS一般人都不用,所以,文章中它是最后一次露面了。
Appium在iOS端自動化測試底層使用的是官方的UI Autoamtion。在Android端,4.2以上使用的官方的Uiautomator,4.1以下使用的時eBay的selendroid。所以在輸入中文的問題上,三個平臺理論上都有可能遇到問題。本文之后將重點調研Uiautomator的輸入中文的問題。
關于中文輸入的的結論:
selendroid的調研之后補充。
首先先來說一下UI Automation。蘋果官方的UI Automation在輸入時有兩種方法:
以上兩個方法在模擬器上都是完美支持中文的。所以不管在iOS上面怎么玩,都是支持中文的。當然兩個方式是有區別的。方法(1)簡單直接,基本上就是一個簡單的set方法。輸入時不會觸發什么類似textChanged事件。方法(2)需要很多支持,方法二是完全模擬人手工輸入過程。蘋果對英文以外的輸入都做了很好地兼容。
Appium iOS版本的 sendkeys方法,直接對應 UIAKeyboard的typeString方法。由于typeString方法完美支持中文。所以Appium iOS版本也就支持中文了。當然,typeString方法也有缺點。當一個輸入框內有內容的時候,typeString的輸入方法是添加,所以,如果之前的內容不需要的時候,還需要先清除掉,在進行typeString。在沒有特殊要求的情況下,我比較喜歡setValue這個方法,但是遺憾的時Appium不支持直接setValue。
之所以能有這篇文章,主要是因為最近想使用Appium做一些App之間相互跳轉的自動化確認測試。一個中文的App,如果不能輸入中文基本上就是歇菜。在使用學習工具的時候發現了很多坑,不能輸入中文的這個坑最大,最郁悶。所以,把自己的調研方法寫出來,供大家參考。
首先 在一切未知的情況下,使用了這個方法進行輸入:
input.sendKeys("舌尖上的中國");
發現結果不對,然后嘗試了不輸入中文:
input.sendKeys("ssssssss");
結果也不對,發現手機上使用的輸入法是Google中文輸入法。把輸入法切換到英文輸入法,以后,英文的正確的了,中文的還是有問題。于是Google了一下,找到了一個帖子。上面信息量很大,看起來比較靠譜的是有一個方法,利用JS運行器來直接輸入方法,翻譯為Java版本以后,代碼如下:
Java 1 2 3 | |
這個方法會出現一個沒有實現的異常。
好吧,看源碼。
在使用Appium 的sendkeys方法是,Client會發送一個http請求到Appium的server。在AppiumServer端的源碼中 有一個 rounting 的文件,輸入方法會發送這樣的路由: rest.post(‘/wd/hub/session/:sessionId?/element/:elementId?/value’, controller.setValue); 然后樹藤摸瓜,找到controller的setValue方法。然后一步一步的查找,最終會找到bootstrap項目中的AndroidElement.java文件,其中有setText方法。代碼如下:
Java 1 2 3 4 5 6 7 8 9 10 | |
在Appium Android Uiautomator中,輸入方法就是這一段代碼。從這一段代碼中會發現Appium基本沒有做什么事情,最終調用了Uiautomator本身的setText方法。所以,接下來需要確認原生的Uiautomator是否可以支持中文輸入。 經過簡單的測試發現,Uiautomator不支持中文輸入,然后繼續Google解決方案。發現了一個uiautomator-unicode-input-helper開源項目。直接拿來嘗試了中文,也發現不對。按照作者的說法是可以支持日語,但是貌似想支持中文的話,還要進行一定量的開發。
繼續看看Uiautomator為什么不支持中文。然后繼續找Android的源碼,發現Uiautomator的所有的功能都是通過UiAutomatorBridge來完成的。在UiAutomatorBridge類中有一個成員變量類型是InteractionController。輸入是通過InteractionController來實現的。具體的setText方法代碼如下:
Java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | |
通過這段代碼,基本上就明白了,Android的Uiautomator完全沒有兼容英文以外的輸入法的意思。并且也沒有提供直接設置屬性的方法。
Appium Android Uiautomator 要支持輸入中文還有很長的一段路需要走。傷心了。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。