po模型介绍

在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与面向对象的特征相 同),通常PO模型可以大大提高测试用例的维护效率

优点:重用,业务和对象分离,代码结构清晰,方便代码维护

PO的核心要素

1.在PO模式中抽离封装集成一个BasePage类,该基类应该拥有一个只实现webdriver实例的属性 2.每一个page都继承BasePage,通过driver来管理本page中元素,将page中的操作封装成一个个方法

3.TestCase继承unittest.Testcase类,并依赖page类,从而实现相应的测试步骤
代码展示

 代码分析

不同的运行脚本环境,游览器不同:驱动webdriver.Firefox()可以剥离 请求地址的变化(生产环境和测试环境):url = http://www.baidu.com可以剥离 操作元素时,常常要等待元素加载完成方可进行操作:可以把webdriver提供的find_element*方法封 装,在元素操作前,先判断元素是否可以操作 实际测试场景中,可能有多个测试场景,如果每个测试场景都需要维护url,游览器驱动,元素定位等,效 率会非常低 因此基于以上分析,是否可以设计一个所有测试界面(selenium本身是B/S系统开展测试)的基类,来 维护公共的方法,此处定义名字为BasePage.py,用于存放页面公共方法及webdriver原有方法二次封装等。

PO实现

实现BasePage

BasePage代码实现

 实现SearchPage

SearchPage代码实现

 实现TestCase

TestCase代码

总结

PO设计模式中的BasePage基类对应案例中的BasePage.py文件

PO模式中的pages中的案例显示Search.py

PO模式设计中TestCase对应案例中的TestCase.py

PO模式的优点 

1:PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰

2:页面对象与用例分离,使得我们更好的复用对象 3:可复用的页面方法代码会变得更加优化

4:更加有效的命令方式使得我们更加清晰的知道方法所操作的UI元素

多个page(界面)的操作 

提供一个basepage类

多个page(界面)的操作 

提供一个basepage类

from selenium.webdriver.support.ui import WebDriverWait # 显示等待
from selenium.webdriver.support import expected_conditions as EC # 期望条件
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains #鼠标操作
class BasePage():
'''BasePage封装所有界面都公用的方法。例如driver,find_element等'''
def __init__(self,driver):
self.driver = driver
# 进入网址
def get(self,url):
self.driver.get(url)
#元素定位,替代八大定位
def get_element(self,*locator):
return self.driver.find_element(*locator)
#点击
def left_click(self,*locator):
ActionChains(self.driver).double_click(self.get_element(*locator)).perform()
#输入
def send_text(self,text,*locator):
self.driver.find_element(*locator).send_keys(text)
#清除
def clear_text(self,*locator):
self.driver.find_element(*locator).clear()
#用于断言
def get_attribuit_value(self,name,*locator):
return self.get_element(*locator).get_attribute(name)
def get_title(self):
return self.driver.title
def get_current_url(self):
return self.driver.current_url
def get_element_text(self,*locator):
return self.driver.find_element(*locator).text
def switch_iframe(self,*locator):
self.driver.switch_to.frame(self.driver.find_element(*locator))
#显示等待
def find_element_by_wait(self,*locator):
element =
WebDriverWait(self.driver,10,0.5).until(EC.presence_of_element_located((locator[
0],locator[1])))
return element
多个page(界面操作)

page1:在游览器中访问:qq邮箱(https://qzone.qq.com/)

'''
实现步骤:(1)继承basepage,(2)元素传参,(3)调取方法
'''
from po10.basepage.base_page import BasePage
from selenium.webdriver.common.by import By
class DLpage(BasePage):
def __init__(self,driver):
BasePage.__init__(self,driver)
def open_qq(self,url):
self.get(url)
def dlget_title(self):
self.get_title()
 page2:在page2中在表单中输入用户名和密码,

from po10.basepage.base_page import BasePage
from selenium.webdriver.common.by import By
class BDpage(BasePage):
def __init__(self,driver):
BasePage.__init__(self,driver)
def bd_switch_frame(self):
self.switch_iframe(By.ID,"login_frame")
def click_zhmmdl(self):
self.left_click(By.ID,"switcher_plogin")
def clear_zh(self):
self.clear_text(By.ID,"u")
def send_zh(self,text):
self.send_text(text,By.ID,"u")
def clear_mm(self):
self.clear_text(By.ID,"p")
def send_mm(self,text):
self.send_text(text,By.ID,"p")
def clink_login(self):
self.left_click(By.ID,"login_button")
def dyys(self):
self.get_element_text(By.ID,"forgetpwd")
 page3:在主界面中点击留言板

from po10.basepage.base_page import BasePage
from selenium.webdriver.common.by import By
class ZjmClass(BasePage):
def __init__(self,driver):
BasePage.__init__(self,driver)
def click_lyb(self):
self.left_click(By.XPATH,".//*[@id='menuContainer']/div/ul/li[4]/a")
单元测试

import unittest
from selenium import webdriver
from po10.pages.dlpage import DLpage
from po10.pages.bdpage import BDpage
from po10.pages.zjmpage import ZjmClass
class Baidu(unittest.TestCase):
@classmethod
def setUpClass(cls) -> None:
cls.driver =webdriver.Firefox()
cls.driver.maximize_window()
cls.driver.implicitly_wait(30)
def test_01qq(self):
url ="https://qzone.qq.com/"
s= DLpage(self.driver)
s.open_qq(url)
def test_02bd(self):
db = BDpage(self.driver)
db.bd_switch_frame()
db.click_zhmmdl()
db.clear_zh()
db.send_zh("766603163")
db.clear_mm()
db.send_mm("lly19891024lly")
db.clink_login()
def test_03zjm(self):
zjm = ZjmClass(self.driver)
zjm.click_lyb()
@classmethod
def tearDownClass(cls) -> None:
cls.driver.close()
if __name__ == '__main__':
unittest.main()
生成测试报告 


import unittest
from testcase.test02 import Baidu
from tooldemo.HTMLTestRunner import HTMLTestRunner
class HtmlClass():
def htmlMethod(self):
suite = unittest.TestSuite() # 创建测试套件
case_list = ["test_01qq","test_02bd","test_03zjm"]
for case in case_list:
suite.addTest(Baidu(case))
with open("../report.html","wb") as f:
HTMLTestRunner(
stream=f,
title="单元测试",
description="测试一期",
verbosity=2
).run(suite)
htmlclass = HtmlClass()
htmlclass.htmlMethod()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值