Selenium基于Python web自动化测试框架 -- PO
关于selenium测试框架首先想到的就是PO模型,简单说下PO模型
PO模型的概念和理解:
PO就是一个设计思想,将代码以页面为单位进行组织,针对这个页面上的所有信息、相关操作都放到一个类中,从而使具体的测试用例变成了简单的调用和验证操作。
优点:进行了拆分和分层
缺点:对于复杂的业务page层变了,case也需要去改动
PO模型的目录结构:
其中,base_page是login_page、search_page的基础。test_login调用login_page,login_page调用base_page,同理test_search。
PO代码示例:
base_page.py
- from selenium.webdriver.support.wait import WebDriverWait
- '''
- 这个类主要是完成所有页面的一些公共方法的封装
- '''
- class Action(object):
- #初始化
- def __init__(self,se_driver):
- self.driver = se_driver
- #定义open方法
- def open(self,url):
- self.driver.get(url)
- self.driver.maximize_window()
- #重写元素定位的方法
- def find_element(self,*loc):
- try:
- WebDriverWait(self.driver,).until(lambda driver:driver.find_element(*loc).is_displayed())
- return self.driver.find_element(*loc)
- except Exception as e:
- print("未找到%s"%(self,loc))
- #定义script方法,用于执行js脚本
- def script(self,src):
- self.driver.execute_script(src)
- #重写send_keys方法
- def send_keys(self,loc,value,clear_first=True,clik_first=True):
- try:
- if clik_first:
- self.find_element(*loc).click()
- if clear_first:
- self.find_element(*loc).clear()
- self.find_element(*loc).send_keys(value)
- except AttributeError:
- print("未找到%s"%(self,loc))
login_page.py
- from selenium.webdriver.common.by import By
- from seleniumframework.PO import base_page
- import time
- class LoginPage(base_page.Action):
- link_loc = (By.LINK_TEXT,"登录")
- name_loc = (By.ID,"TANGRAM__PSP_8__userName")
- password_loc = (By.ID,"TANGRAM__PSP_8__password")
- submit_loc = (By.ID,"TANGRAM__PSP_8__submit")
- username_top = (By.LINK_TEXT,"hanxiaobei")
- def click_link(self):
- self.find_element(*self.link_loc).click()
- time.sleep() #等待3秒,等待登录弹窗加载完成
- def run_case(self,value1,value2):
- self.find_element(*self.name_loc).send_keys(value1)
- self.find_element(*self.password_loc).send_keys(value2)
- time.sleep() #手动输入验证码
- self.find_element(*self.submit_loc).click()
- time.sleep() #等待5秒,登录后的页面加载完成
- def get_username(self):
- return self.find_element(*self.username_top).text
test_login.py
- import unittest
- from selenium import webdriver
- from seleniumframework.PO.login_page import LoginPage
- import time
- class TestBaiduLogin(unittest.TestCase):
- """UI自动化登录"""
- def setUp(self):
- self.url = "http://www.baidu.com"
- self.driver = webdriver.Firefox()
- self.driver.implicitly_wait()
- # self.verificationErrors = []
- def tearDown(self):
- time.sleep()
- self.driver.quit()
- # self.assertEqual([],self.verificationErrors)
- def test_login(self):
- """百度登录"""
- sp = LoginPage(self.driver)
- sp.open(self.url)
- sp.click_link()
- sp.run_case("hanxiaobei","xxxxxxx")
- self.assertEqual(sp.get_username(),"hanxiaobei",msg="验证失败!")
main.py 运行的主入口
- import unittest
- import HTMLTestRunner
- #相对路径
- testcase_path = ".\\testcase"
- report_path = ".\\report\\report.html"
- def creat_suite():
- uit = unittest.TestSuite()
- discover = unittest.defaultTestLoader.discover(testcase_path,pattern="test_*.py")
- for test_suite in discover:
- # print(test_suite)
- for test_case in test_suite:
- uit.addTest(test_case)
- return uit
- suite = creat_suite()
- fp = open(report_path,"wb")
- runner = HTMLTestRunner.HTMLTestRunner(stream=fp,title="测试结果",description="测试搜索结果")
- runner.run(suite)
- fp.close()
解决报告命名的问题:
- now = time.strftime("%Y-%m-%d-%H-%M-%S",time.localtime(time.time()))
- print(now)
- 3 report_path = ".\\report\\"+now+"report.html"
测试报告截图:
search_page.py
- from selenium.webdriver.common.by import By
- from seleniumframework.PO import base_page
- #继承base后既可以调用base的方法也可自己添加新的方法
- class SearchPage(base_page.Action):
- #通过id进行定位元素
- search_loc = (By.ID,"kw")
- def run_case(self,value):
- #第一种利用原生的send_keys方法
- self.find_element(*self.search_loc).send_keys(value)
- #第二种利用二次封装的send_keys方法
- # self.send_keys(self.search_loc,value)
test_search.py
- import unittest
- from selenium import webdriver
- from seleniumframework.PO.search_page import SearchPage
- import time
- class TestBaiduSearch(unittest.TestCase):
- """UI自动化搜索"""
- def setUp(self):
- self.url = "http://www.baidu.com"
- self.driver = webdriver.Firefox()
- self.driver.implicitly_wait()
- self.verificationErrors = []
- def tearDown(self):
- time.sleep()
- self.driver.quit()
- self.assertEqual([],self.verificationErrors)
- def test_search(self):
- """搜索测试关键字"""
- sp = SearchPage(self.driver)
- sp.open(self.url)
- sp.run_case("测试")
Selenium基于Python web自动化测试框架 -- PO的更多相关文章
- 基于Python接口自动化测试框架+数据与代码分离(进阶篇)附源码
引言 在上一篇<基于Python接口自动化测试框架(初级篇)附源码>讲过了接口自动化测试框架的搭建,最核心的模块功能就是测试数据库初始化,再来看看之前的框架结构: 可以看出testcase ...
- Web自动化测试框架-PO模式
Web自动化测试框架(WebTestFramework)是基于Selenium框架且采用PageObject设计模式进行二次开发形成的框架. 一.适用范围:传统Web功能自动化测试.H5功能自动化测试 ...
- python web自动化测试框架搭建(功能&接口)——功能测试模块
功能测试使用selenium,模块有: 1.futil: 公共方法,如元素高亮显示 # coding=utf-8 """高亮显示元素""" ...
- python web自动化测试框架搭建(功能&接口)——测试用例执行和结果收集
由于unittest框架中结果收集在不同文件中,所以此处重写结果收集方法,加入执行时间,失败信息,失败截图等 TestRunner.py # coding=utf-8 import sys impor ...
- python web自动化测试框架搭建(功能&接口)——环境搭建
自动化测试框架一般需要实现以下通用功能 执行前准备 结束后清理 执行步骤输出 执行结果输出 错误.失败截图 测试报告 发送邮件 日志 需要的软件和python第三方库有: 通用: JDK Eclips ...
- Selenium基于Python web自动化基础一 -- 基础汇总及简单操作
Selenium是UI层WEB端的自动化测试框架,也是目前市面上比较流行的自动化测试框架. ui层自动化测试本质是什么?模拟用户的真实操作行为. 基础汇总: 导入所需要的模块 from seleniu ...
- python web自动化测试框架搭建(功能&接口)——接口用例实现
测试用例基类: # coding=utf-8 import unittest import Logger log = Logger.Loger() class BaseCase(unittest.Te ...
- python web自动化测试框架搭建(功能&接口)——接口公共方法
接口公共方法有:数据引擎.http引擎.Excel引擎 1.数据引擎:获取用例.结果检查.结果统计 # -*- coding:utf-8 -*- from XlsEngine import XlsEn ...
- python web自动化测试框架搭建(功能&接口)——接口测试模块
Python接口测试采用python读取excel的方法,通过requests库发送请求和接收响应.模块有: Data:用于存放excel用例的,用例格式: iutil: 接口公共方法,数据引擎.ht ...
随机推荐
- 剑指Offer - 两个链表第一个公共节点
https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?tpId=13&tqId=11189&tPage= ...
- 怎样用ccache加速cocos2d-x android版本号的编译
下面步骤在MAC下測试通过: 首先是安装CCache, 能够用homebrew brew install --HEAD ccache 也能够用源代码安装 git clone https://githu ...
- 【剑指Offer学习】【面试题31:连续子数组的最大和】
题目:输入一个整型数组,数组里有正数也有负数.数组中一个或连续的多个整数组成一个子数组.求全部子数组的和的最大值.要求时间复杂度为O(n). 样例说明: 比如输入的数组为{1, -2, 3, 10, ...
- hdu1863
#include<cstdio> #include<algorithm> using namespace std; int N,M; struct edge { int u,v ...
- python爬虫【第2篇】【多进程】
一.多进程 1.fork方法(os模块,适用于Lunix系统) fork方法:调用1次,返回2次.原因:操作系统经当前进程(父进程)复制出一份进程(子进程),两个进程几乎完全相同,fork方法分别在父 ...
- 容器与容器编排实战系列 1 -- Docker 安装
CentOS7.4 下安装Docker 详细步骤 第一步:安装Docker yum install -y yum-utils device-mapper-persistent-data lvm2 yu ...
- luogu2827 蚯蚓
题目大意 本题中,我们将用符号[c]表示对c向下取整,例如:[3.0」= [3.1」= [3.9」=3. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓 ...
- how to modify vs2017
https://docs.microsoft.com/en-us/visualstudio/install/modify-visual-studio 直接用everything搜索vs_install ...
- gitlab gerrit jenkins CI/CD环境集成
http://blog.csdn.net/williamwanglei/article/details/38498465
- 22.Extjs Panel中显示多行工具栏(tbar)
转自:http://blog.sina.com.cn/s/blog_454fbf740100t0xj.html 在应用程序的制作中,我们经常性的会用到工具栏,在Extjs中Panel中提供了tbar和 ...