Appium 自动化测试(Java)

Appium 自动化测试(Java)

元素定位方法

一、App定位元素

1、通过ID定位元素,对应【resource-id】属性

这里写图片描述

driver.findElementById(“me.ele:id/w0”);

代码如下:

@Test

public void doClick() {

    //通过id查找元素

    WebElement el = driver.findElement(By.id("com.tencent.mm:id/do"));

    el.click();

    //等待3s观察显示

    try {

    Thread.sleep(3000);

    } catch(InterruptedException e) {

    e.orintStackTrace();

    }

}
2、通过Name定位元素,对应【text】属性

这里写图片描述

driver.findElementByName(“外卖”);

代码如下:

@Test

public void doClick() {

    //通过name查找元素

    WebElement el = driver.findElement(By.name("昵称"));

    el.click();

    //等待3s观察显示

    try {

    Thread.sleep(3000);

    } catch(InterruptedException e) {

    e.orintStackTrace();

    }

}
3、通过ClassName定位元素,对应【class】属性

这里写图片描述

driver.findElementsByClassName(“android.widget.TextView”);

代码如下:

@Test

public void doClick() {

    //通过classname查找元素

    WebElement el = driver.findElement(By.ClassName("android.widget.TextView"));

    el.click();

    //等待3s观察显示

    try {

    Thread.sleep(3000);

    } catch(InterruptedException e) {

    e.orintStackTrace();

    }

}
4、通过Xpath定位元素,对应【xpath】属性

这里写图片描述

driver.findElementByXPath(“//android.widget.Button[@index=’1’]”);

代码如下:

@Test

public void doClick() {

    //通过xpath查找元素

    WebElement el = driver.findElement(By.xpath("//android.widget.Button[@index='1']"));

    el.click();

    //等待3s观察显示

    try {

    Thread.sleep(3000);

    } catch(InterruptedException e) {

    e.orintStackTrace();

    }

}
5、通过AccessibilityId定位元素,对应【content-desc】属性

这里写图片描述

driver.findElementByAccessibilityId(“我的”);

代码如下:

@Test

public void doClick() {

    //通过AccessibilityId查找元素

    WebElement el = driver.findElementByAccessibilityId("sharebutton");

    el.click();

    //等待3s观察显示

    try {

    Thread.sleep(3000);

    } catch(InterruptedException e) {

    e.orintStackTrace();

    }

}
6、通过AndroidUiAutomator定位元素

AndroidUIAutomator是一个强有力的元素定位方式,它是通过Android UIAutomator类库去找元素,定位方式:

findElement(By.AndroidUIAutomator(String UIAuto));

可以选择id,nameclassName,description作为传入的字符串

WebElement el =

driver.findElementByAndroidUIAutomator("new UiSelector().resourceId(\"com.tencent.mm:id/do\")");

代码如下:

@Test

public void doClick() {

    //通过AndroidUIAutomator查找元素

    WebElement el = driver.findElementByAndroidUIAutomator("new UiSelector().description(\"sharebutton\")");

    el.click();

    //等待3s观察显示

    try {

    Thread.sleep(3000);

    } catch(InterruptedException e) {

    e.orintStackTrace();

    }

}

二、处理纯web应用元素定位

1、 chrome toggle device mode 模式

这是谷歌提供的一个移动端Web开发调试工具,通过它我们可以调试手机页面。通过调试我们可以看到wap页面的源码,从而进行元素的定位。那么这个工具该如何使用呢?首先你要有一台PC,上面安装了chrome浏览器;一台安卓手机,上面安装了chrome移动版的浏览器。将你的手机通过USB数据线连接到你的PC机并开启USB调试模式(由于每个机器不一样,所以开启USB模式的方式就不再详细说明),然后在CMD中输入adb devices看看设备是不是链接成功了:

clipboard[5]

接下来在PC机上打开chrome浏览器

然后在地址栏输入:chrome://inspect/#devices

clipboard[6]

紧接着在你的Android手机上打开chrome浏览器并输入百度首页地址:

当你打开了百度首页之后,我们在回到PC版的chrome浏览器上面的chrome://inspect/#devices页面下观察:

clipboard[7]

接下来点击”inspect”,你会发现弹出一个新窗口,如图:

clipboard[8]

通过此图大家可以看到手机屏幕上的页面已经PC机上显示了,你可以看到手机wap页面源码以及UI界面。使用用DevTools特别重要的一点是:如果你点击inspect打开的DevTools窗口一片空白,且刷新无效时,那极有可能是由于被墙的缘故。

在hosts文件最后追加以下内容:

混合应用是原生APP+webview组成的,可以简单的理解为一个原生app的外壳,内部全是html页面。在WebView类中调用静态方法setWebContentsDebuggingEnabled,如下:

64.233.162.83 chrome-devtools-frontend.appspot.com

保存之后,在CMD中输入:ipconfig /flushdns

刷新DNS之后,打开的DevTools窗口就不会在是空白的了。

在DevTools窗口顶部有个“Select an element in the page to inspect it”按钮,如下图所示:clipboard[9]

百度一下button的元素信息

clipboard[10]

通过id定位:

WebElement searchButton = driver.findElement(By.id(“index-bn”))

百度搜索关键字的代码:

public AndroidDriver<WebElement> driver;

@BeforeClass

public void startTest() throws MalformedURLException {

DesiredCapabilities capabilities = new DesiredCapabilities();

capabilities.setCapability("platformName","Android");

capabilities.setCapability("deviceName","MeiZu MX3");

capabilities.setCapability("platformVersion", "5.0.1");

capabilities.setCapability("browserName", "Chrome");

driver = new AndroidDriver<WebElement>(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);

driver.manage().timeouts().implicitlyWait(6, TimeUnit.SECONDS);

}

@AfterClass

public void afterClass() {

driver.quit();

}

@Test

public void addContact() {

//打开百度首页

driver.get("https://www.baidu.com");

//输入框元素

WebElement inputBox = driver.findElement(By.id("index-kw"));

//输入JAVA关键字

inputBox.sendKeys("JAVA");

//百度一下按钮

WebElement searchButton = driver.findElement(By.id("index-bn"));

//点击百度一下按钮

earchButton.click();

try {

Thread.sleep(2000);

} catch (InterruptedException e) {

e.printStackTrace();

}

}
2.1chrome toggle device mode 模式

####打开PC chrome浏览器,点击F12

clipboard[11]

点击toggle device mode,F5刷新就可以实现方式1的效果,而且比方式1简单。

clipboard[12]

可以切换设备型号及屏幕的大小。

三、定位混合应用元素

混合应用是原生APP+webview组成的,可以简单的理解为一个原生app的外壳,内部全是html页面。在处理这样的app的定位的时候 需要先定位原生APP上的按钮或者链接,然后点击按钮或者链接,然后经过appium提供的方法,进入webview页面,通过之前介绍的定位工具和方法进行元素定位了。如果说你的android版本小于4.4,那么你需要使用Selendroid模式来作为测试引擎,在测试初始化的时候需要设置该capability。如果你的android版本大于等于4.4,那么Appium作为测试引擎,然后通过chromedriver来处理webview。如果你使用的是APPIUM测试引擎,调试WebView需要满足安卓系统版本为Android 4.4+已上,并且需要在你的APP内配置相应的代码,在WebView类中调用静态方法setWebContentsDebuggingEnabled,如下:

if (Build.VERSION.SDK_INT >=Build.VERSION_CODES.KITKAT) {

WebView.setWebContentsDebuggingEnabled(true);

}

进入webview的操作:

//这里使用driver.getContextHandles();获取app的handles,原生应用会有一个handle,webview也会有一个handle

Set<String> contexts = driver.getContextHandles();

for(String cotext:contexts) {

    System.out.println(context);

//会打印出  NATIVE_APP(原生app handle)和WEBVIEW_com.example.testapp(webview的 handle)

}

//进入webview中

driver.context((String) contexts.toArray()[1]);

//操作webview中的内容

这里使用driver.getContextHandles();获取app的所有handles,原生应用会有一个NATIVE_APP 的handle,webview也会有一个WEBVIEW_XXX_XXX_XX的handle,确定了webview的handle之后,使用:driver.context(handle的字符串)进入webview页面

元素等待类型

sleep():强制等待

固定的等待时间

Thread.sleep(6000) //强制等待6s
implicitly_wait():隐士等待

针对全局元素设置等待时间 (单位 秒/s )

它是 webdirver 提供的一个超时等待。隐式等待一个元素被发现,或一个命令完成。如果超出了设置时间仍未定位到元素则抛出异常。
#当使用了隐士等待执行测试的时候,如果 WebDriver没有在 DOM中找到元素,将继续等待,超出设定时间后则抛出找不到元素的异常
#换句话说,当查找元素或元素并没有立即出现的时候,隐式等待将等待一段时间再查找 DOM,默认的时间是0
#一旦设置了隐式等待,则它存在整个 WebDriver 对象实例的声明周期中,隐式的等到会让一个正常响应的应用的测试变慢,
#它将会在寻找每个元素的时候都进行等待,这样会增加整个测试执行的时间。

#implicitly_wait()方法比 sleep() 更加智能,后者只能选择一个固定的时间的等待,前者可以在一个时间范围内智能的等待。

androidDriver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
WebDriverWait():显式等待

​ 针对某个元素设置等待时间

同样也是 webdirver 提供的方法。在设置时间内,默认每隔一段时间检测一次当前。页面元素是否存在,如果超过设置时间检测不到则抛出异常。
详细格式如下:

WebDriverWait
  • driver : WebDriver 的驱动程序(Ie, Firefox, Chrome 或远程)
  • timeout :最长超时时间,默认以秒为单位
  • poll_frequency :休眠时间的间隔(步长)时间,默认为 0.5 秒
  • ignored_exceptions :超时后的异常信息,默认情况下抛 NoSuchElementException 异常。

WebDriverWai()一般和 until()或 until_not()方法配合使用,下面是 until()和 until_not()方法的说明。

  • until(method, message=’’):调用该方法提供的驱动程序作为一个参数,直到返回值不为 False。
    ver 提供的方法。在设置时间内,默认每隔一段时间检测一次当前。页面元素是否存在,如果超过设置时间检测不到则抛出异常。
    详细格式如下:
WebDriverWait
  • driver : WebDriver 的驱动程序(Ie, Firefox, Chrome 或远程)
  • timeout :最长超时时间,默认以秒为单位
  • poll_frequency :休眠时间的间隔(步长)时间,默认为 0.5 秒
  • ignored_exceptions :超时后的异常信息,默认情况下抛 NoSuchElementException 异常。

WebDriverWai()一般和 until()或 until_not()方法配合使用,下面是 until()和 until_not()方法的说明。

  • until(method, message=’’):调用该方法提供的驱动程序作为一个参数,直到返回值不为 False。
  • until_not(method, message=’’):调用该方法提供的驱动程序作为一个参数,直到返回值为 False。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ji xiao Xing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值