這篇講一下如果找到對應ios/android里的UI控件,以便我們快速地寫測試代碼,本系列文章未特殊提到使用什么語言時,默認使用ruby腳本語言。ios/android設備的UI控件有很多種,下面講一下使用appium Inspector和appium ruby console(arc)來查找UI控件
Appium Inspector GUI
appium服務啟動后,點擊inspector,啟動client GUI,如下圖,GUI已幫我們獲取到所有的Ui控件,并且有很多模擬操作,非常適合我們調試用,點擊record,每個模擬操作都會生成相應的代碼,而且代碼還可以選擇你需要的語言版本。
我們具體定位到某個控件,可以看到這個控件的詳細信息,比如我現在找到一個登錄按鈕,下面是這個登錄按鈕的信息
#android某個控件的詳細信息
content-desc:
type: android.widget.Button
text: 登錄
index: 1
enabled: true
location: {418, 1054}
size: {262, 89}
checkable: false
checked: false
focusable: true
clickable: true
long-clickable: false
package: com.yydys
password: false
resource-id: com.yydys:id/immediate_experience
scrollable: false
selected: false
xpath: //android.widget.LinearLayout[1]/android.widget.FrameLayout[1]/android.widget.LinearLayout[1]/android.widget.LinearLayout[1]/android.widget.LinearLayout[2]/android.widget.Button[2]
#ios某個控件下的詳情信息
name: 登錄
type: UIAButton
value:
label: 登錄
hint:
enabled: true
visible: true
valid: true
location: {192.5, 575}
size: {167.5, 44}
xpath: //UIAApplication[1]/UIAWindow[2]/UIAScrollView[1]/UIAButton[2]
appium ruby console(arc)
ruby_console是針對ruby打造的一個console端的gem,使用起來也很方便,直接在console里使用命令arc就能啟動設備,不過他并不能讀取我們在appium里面的配置信息,所以需要我們手動創建一個appium.txt文件,在此文件目錄下面啟動,下面的android/ios的appium.txt文件
#android
[caps]
platformName = "Android"
platformVersion = '5.1'
app = "/Users/xuyao/Downloads/Yydys0627.apk"
deviceName = "Android Simulator"
#ios
[caps]
platformName = "ios"
platformVersion = '8.2'
app = "/Users/xuyao/Downloads/Cloudoc-Patient.app"
deviceName = "iPhone Simulator"
#啟動arc
? ls
appium.txt
? arc
[1] pry(main)>
啟動后,我們可以通過page方法查看當前頁面所有的元素
[4] pry(main)> page
android.widget.FrameLayout (1)
id: android:id/content
android.support.v4.view.ViewPager (0)
id: com.yydys:id/vp_welcome
android.widget.ImageView (0)
id: com.yydys:id/wel_img
android.widget.Button (0)
text: 逛一逛
id: com.yydys:id/direct_access
strings.xml: direct_access
android.widget.Button (1)
text: 登錄
id: com.yydys:id/immediate_experience
strings.xml: immediate_experience
login
nil
如果覺得頁面信息很多,找不到自己想要的控件,page方法后面可以帶個參數class_name來過濾元素,如下
[5] pry(main)> page :Button
android.widget.Button (0)
text: 逛一逛
id: com.yydys:id/direct_access
strings.xml: direct_access
android.widget.Button (1)
text: 登錄
id: com.yydys:id/immediate_experience
strings.xml: immediate_experience
login
nil
這樣就能找到按鈕的元素了
find_element()方法
根據上面的信息我們可以通過find_elment方法來查找android/ios下的xpath,模擬點擊操作
#android
find_element(xpath: "http://android.widget.LinearLayout[1]/android.widget.FrameLayout[1]/android.widget.LinearLayout[1]/android.widget.LinearLayout[1]/android.widget.LinearLayout[2]/android.widget.Button[2]").click
#android我們還可以根據他的recource-id,來查找他的唯一控件
find_element(id: "com.yydys:id/immediate_experience").click
#ios
find_element(xpath: "http://UIAApplication[1]/UIAWindow[2]/UIAScrollView[1]/UIAButton[2]").click
#當然你也可以通過class_name來查找,如果一個頁面上有多個相同的class_name,會返回第一個tag
find_element(class_name: "android.widget.Button").click #android
find_element(class_name: "UIAButton").click
button_exact方法
有時候我們知道要找一個按鈕,那么我們可以使用button_exact來直接查找一個button,button_exact方法會找到第一個配置到的元素
[8] pry(main)> button_exact("登錄")
#<Selenium::WebDriver::Element:0x5dffe05a97580bc2 id="3">
textfield_exact()方法
根據給定的值找到EditText/TextFeild第一個元素
[24] pry(main)> textfield_exact("com.yydys:id/login_input").type "9123"
true
exists()方法
測試的時候一般需要判斷某個元素是否存在,可以使用exists
[40] pry(main)> exists{button_exact("com.yydys:id/login_btn")}
true
以上就是一些比較常用的方法,以后用到再更新一些新的方法
參考資料
https://github.com/appium/ruby_lib/blob/master/docs/android_docs.md
https://github.com/appium/ruby_lib/blob/master/docs/ios_docs.md
https://ruby-china.org/topics/30154