selenium自动化接口(web端)+PO模型
一
看一自己安装哪种类型浏览器,并去下载相对应浏览器版本驱动器
谷歌浏览器驱动器链接:http://chromedriver.storage.googleapis.com/index.html
如果是别得浏览器就去下载对应的驱动包,下载好后就放在安装Python主目录里
然后再PycChram中下载插件selenium
屏幕截图 2020-11-01 191332.png
搜索Project Interpeter,在右边绿色加号下载
屏幕截图 2020-11-01 191423.png
下载好后,导包是不会错的
屏幕截图 2020-11-01 191456.png
接下来就是代码了,就不做多解释了,在这里网址就不显示了,可以自行添加网址
导包
from selenium import webdriver
import time
from selenium.webdriver.common.action_chains import ActionChains
db = webdriver.Chrome() #建立驱动浏览器对象
db.get("") #get(url) 对象打开浏览器并将网址作为参数
db.maximize_window() #屏幕最大化
time.sleep(1)
a = db.find_element_by_class_name("text_cmu") #输入账号
time.sleep(1)
a.send_keys("13800138006")
b = db.find_element_by_id("password") #输入密码
time.sleep(2)
b.send_keys("123456")
c = db.find_element_by_id("verify_code") #输入验证码
time.sleep(2)
c.send_keys("1111111")
d = db.find_element_by_class_name("J-login-submit").click() #点击登陆
time.sleep(2)
e = db.find_element_by_link_text("首页").click() #进入到首页
这是悬停,和句柄,使可以添加商品到支付页面
f=db.find_element_by_xpath("//*[@id='cata-nav']/div[3]")
ActionChains(db).move_to_element(f).perform()
time.sleep(1)
db.find_element_by_link_text("平板电脑").click()
time.sleep(2)
hdle = db.current_window_handle
list = db.window_handles
for hd in list:
if hd != hdle:
db.switch_to_window(hd)
print(db.title)
db.find_element_by_xpath("/html/body/div[4]/div/div[2]/div[2]/ul/li/div").click()
f = db.find_element_by_xpath('//*[@id="join_cart"]').click()
time.sleep(3)
db.switch_to_frame("layui-layer-iframe1")
db.find_element_by_xpath('//*[@id="addCartBox"]/div[1]/div/div/a[2]').click()
time.sleep(3)
db.find_element_by_xpath('/html/body/div[4]/div/div/div/div[2]/div[2]/div[1]/a').click()
time.sleep(3)
i = db.find_element_by_xpath('/html/body/div[14]/div/button').click()
time.sleep(3)
j = db.find_element_by_xpath('//*[@id="cart4_form"]/div/div/dl/dd/div/div[2]/ul/li[2]/div/label/img').click()
time.sleep(3)
k = db.find_element_by_xpath('//*[@id="cart4_form"]/div/div/div/a').click()
time.sleep(3)
这是最后的效果
屏幕截图 2020-11-01 192159.png
PO模型
PO是什么:
1、页面对象模型(PO)是一种设计模式,用来管理维护一组web元素的对象库
2、在PO下,应用程序的每一个页面都有一个对应的page class
3、每一个page class维护着该web页的元素集和操作这些元素的方法
4、page class中的方法命名最好根据对应的业务场景进行,例如通常登录后我们需要等待几秒钟,
为什么要po,----po能让我们的测试代码变得可读性更好,可维护性高,复用性高。
PO的优势
1、PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰。
2、页面对象与用例分离,使得我们更好的复用对象。
3、可复用的页面方法代码会变得更加优化
4、更加有效的命名方式使得我们更加清晰的知道方法所操作的UI元素。例如我们要回到首页,
方法命名为:gotoHomePage(),通过方法名即可清晰的知道具体的功能实现。
PO模型参考链接:https://www.cnblogs.com/zihkj/p/12164079.html
设置selenium的元素等待
有三种:
显示等待:(WebDriverWait)
原理:就是明确的要等到某个元素的出现或者是某个元素的可点击等条件,等不到就一直等,除非在规定时间之内都没还找到,才会报错,简单来说,就是知道元素出现才去操作,如果超时则报异常
隐式等待:(driver.implictly_wait)
原理:就是在创建driver时,为浏览器对象创建一个等待时间,这个方法是得不到某个元素就等待一段时间,直到拿到某个元素为止,注意:在使用隐式等待得时候,实际上浏览器会在你自己设定得时间内部不断得刷新页面而去寻找我们需要得元素
死等:(Time.sleep)
使当前线程进入等待,time.sleep(),这种就是死等,很容易让线程停掉,使程序抛异常