开篇闲扯
生活就像一把吉他,弹不响也要弹,bug就像测试的头发,又浓又密!
生活中的疯子宣布:“QQ测试项目正式开始”
小白新秀
一件作品的开始总是丑陋的
实现,QQ应用底部导航控件之间的点击跳转
定位元素文件内容
nav:
- android:id/tabs
- android.widget.RelativeLayout
- android.widget.FrameLayout
python 测试脚本代码
from appium import webdriver
from time import sleep
import yaml
def read_yaml():
with open('duntil.yaml', 'r') as fb:
return yaml.load(fb)
el = read_yaml()['nav']
class TestKe(object):
def __init__(self):
self.d = {
"device": "android",
"platformName": "Android",
"platformVersion": "9",
"deviceName": "46HDU19314003325",
"appPackage": "com.tencent.mobileqq",
"appActivity": ".activity.SplashActivity",
"noReset": "true"
}
self.dr = webdriver.Remote("http://127.0.0.1:4723/wd/hub", desired_capabilities=self.d)
sleep(10)
def change_nav(self):
a = self.dr.find_element_by_id(el[0]).find_elements_by_class_name(el[2])
for i in a:
i.click()
print(a)
def close(self):
self.dr.quit()
if __name__ == '__main__':
t = TestKe()
t.change_nav()
t.close()
旧事重提
昨天的问题回答一下
为什么要加入睡眠时间?
appium自动化测试,核心之一是根据xml元素执行模仿人的操作,xml文件的加载速度快于手机渲染UI布局页面的速度,虽然已经在xml文件中找到定位元素,但是UI布局中该元素没有被显示,那么该属性的状态依旧是不可见的状态,所以很多做过自动化测试的小伙伴经常会遇到一个问题,“xx元素找不到”,所以我们要在必要的代码中加入等待时间
appium的三种等待方式
第一种:强制等待 --- time.sleep(浮点数)
强制cup的线程停止xx秒,从而使元素在UI布局中加载出来
from time import sleep
sleep(2.5)
第二种:隐性等待 --- implicitly_wait()
设置最大等待时间,关键字参数:time_to_wait=10,超过最大等待时间后则会抛出异常
self.dr.implicitly_wait(time_to_wait=10)
第三种:安卓独有 --- wait_activity():
在设置的时间内没间隔指定的时间扫描activity是否被找到,找到则执行下面的代码,超过最大等待时间则抛出异常
activity: 安卓活动名,tiemout:超时时间
self.dr.wait_activity(activity=".activity.SplashActivity'', timeout=10)
第四种:智能等待 --- WebDriverWait():在指定的时间内,默认每隔一段时间检测一次当前页面元素是否存在,如果超过设置时间检测不到则抛出异常。
参数信息: driver:指的是webdriver.Remote()对象 timeout: 最长超时时间,默认以秒为单位 poll_frequency:间隔时间,默认为 0.5 秒 ignored_exceptions - 超时后抛出的异常
from selenium import webdriver
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By
locator = (By.ID, "android:id/tabs")
try:
WebDriverWait(driver, 20, 0.5).until(EC.presence_of_element_located((locator))
except:
print("元素未找到")
# 后期这里可以完善为日志
"""
selenium.webdriver.support.expected_conditions 类还包含以下方法
这两个条件类验证title,验证传入的参数title是否等于或包含于driver.title
title_is
title_contains
presence_of_element_located # 判断单一元素是否全部加载出来
presence_of_all_elements_located # 判断多个元素全部加载出来
验证元素是否可见,前两个传入参数是元组类型的locator,第三个传入WebElement
第一个和第三个其实质是一样的
visibility_of_element_located
invisibility_of_element_located
visibility_of
判断某段文本是否出现在某元素中,一个判断元素的text,一个判断元素的value
text_to_be_present_in_element
text_to_be_present_in_element_value
frame_to_be_available_and_switch_to_it # 判断frame是否可切入
alert_is_present # 判断是否有alert出现 alert弹出框
element_to_be_clickable # 这个条件判断元素是否可点击
这四个条件判断元素是否被选中,第一个条件传入WebElement对象,第二个传入locator元组
第三个传入WebElement对象以及状态,相等返回True,否则返回False
第四个传入locator以及状态,相等返回True,否则返回False
element_to_be_selected
element_located_to_be_selected
element_selection_state_to_be
element_located_selection_state_to_be
判断一个元素是否仍在DOM中,传入WebElement对象,可以判断页面是否刷新了
staleness_of
"""
最后一讲
获取控件中的值
首先你找到的元素中text属性必须有值, 然后按照前几篇将的定位方法进行元素定位,再编写脚本
def get_text(self):
b = self.dr.find_element_by_id('android:id/tabs').find_elements_by_class_name('android.widget.TextView')
for i in b:
print(i.text)
# 输出结果是 消息 联系人 看点 动态,一般这些东西用于断言
明天聊
断言
pytest
如何设计测试用例脚本
小记后语
愿明天的日出不像路灯那么昏黄,愿每个测试都能善待开发的头发!阿门