UI⾃动化框架思路整理(Python+selenium+unittest+html)本⽂主要以PO思想将页⾯元素和代码分离,以及执⾏多⽤例的UI⾃动化框架。 下图是整个框架图:
在准备测试⼀个功能时,我们可以通过⼿⼯去测,也可以⽤UI⾃动化框架去实现多⽤例的操作。 ⾃动化框架思路:在拿到⼀个被测业务(功能)时,⾸先想⼀下,如果⽤⼿⼯的⽅式如何去测,需要准
备哪些东西,需要哪些步骤,⽽⾃动化的过程就是代替⼈⼯的实现,所以我们往这个思路上去想不难得出,⼀个测试业务⾸先需要测试驱动(也就是浏览器),测试驱动上需要测试元素(也就是测哪些东西,再通俗⼀点就是所对应的界⾯或者功能),那如何⽤代码调⽤驱动进⾏实现,测试配置就在此起到了决定性的作⽤,将所有的配置好之后要进⾏测试,还需要测试数据和⽤例的准备,最后加⼊测试报告的配置⽤执⾏器执⾏就能够形成最终的测试报告了。这段⽂字主要是梳理思路以及解释上图。还有很多细节以及步骤且听我慢慢道来。 建包:
准备以下七个包:
在每个包内配置⽂件:
1.browserdriver(浏览器驱动)
在browserdriver中放置浏览器驱动
(1)创建config.ini⽂件⾥⾯配置要测试的⽹址和浏览器驱动
(2)创建read_ini.py:读取配置⽂件
源码如下:
#封装成别⼈可以使⽤的代码
import configparser
import os
print(os.path.dirname(os.path.dirname(__file__)))
class joReadIni():
#初始化路径
# 参数1 file_name⽂件名指定⽂件名
# 参数2 node 指定所需要节点名
def __init__(self,file_name=None,node=None):
self.file_name=file_name
if file_name==None:
#⽂件名加r 防⽌⾃动转义
集通信
self.file_name=os.path.dirname(os.path.dirname(__file__))+"/config/config.ini"
if node==None:
热转印烤杯机
self.cf=self.load_ini(self.file_name)
#加载配置⽂件
def load_ini(self,file_name):高建钢
#获取解析配置对象
cf=configparser.ConfigParser()
return cf
#获取配置⽂件中的内容===>指定key
def get_value(self,key):
return (de,key)
#进⾏单元测试
if __name__=='__main__':
aa=joReadIni()
_value("browser"))
(3)创建jo_driver.py:读取浏览器驱动产⽣测试webdriver驱动对象(调取浏览器)
import os
from time import sleep
from selenium import webdriver
ad_ini import joReadIni
#⼯程路径临界反应
parent_path=os.path.dirname(os.path.dirname(__file__))
#专门读取配置⽂件对象
jo=joReadIni()
#获取被测试⽹址
_value("url")
def get_firefox_driver():
driver_path=parent_path+"/browserdriver/geckodriver"
driver=webdriver.Firefox(executable_path=driver_path)
<(url)
driver.maximize_window()
driver.implicitly_wait(3)
sleep(3)
return driver
#进⾏单元测试
if __name__=='__main__':
get_firefox_driver()
3.business(测试业务)
利⽤PO的思想将页⾯元素和代码分离,因此先在business内创建ini元素⽂件,再到config包内创建⼀个py⽂件进⾏元素的查询,即使之后界⾯变了,但是元素是可以复⽤的,因此将其分离开来⽅便代码的管理。
(1)创建LocalElement.ini ⽂件:存放需要⾃动化操作的控件元素和定位⽅式
[jologin]
user_login=xpath>//*[@id="__layout"]/div/div[1]/div[1]/div[3]/div[3]/button[1]/span
user_name=xpath>//*[@id="__layout"]/div/div[1]/div[2]/div/div/div[3]/div/div/div[1]/div/input
user_password=xpath>//*[@id="__layout"]/div/div[1]/div[2]/div/div/div[3]/div/div/section/div/div/input
login_button=xpath>//*[@id="__layout"]/div/div[1]/div[2]/div/div/div[3]/div/div/div[2]/button
[joxuanke]
touxiang=xpath>//*[@id="__layout"]/div/div[1]/div[1]/div[3]/div[3]/div/img
xuexizhongxin=xpath>//*[@id="__layout"]/div/div[1]/div[1]/div[3]/div[3]/div/div/ul/li[1]/span
xuankezhongxin=link_text>选课中⼼
jiagepaixu=xpath>//*[@id="__layout"]/div/div[2]/div/div[2]/div[1]/span[2]
#根据页⾯倒数第三段 div[2]决定了是第⼏个元素
secondkecheng=xpath>//*[@id="__layout"]/div/div[2]/div/div[2]/div[2]/div[2]/div[3]/button
盐屋kaishixuexi=xpath>//*[@id="__layout"]/div/div[2]/div[1]/div/div[3]/div/div[3]/button
# 看是否有评价决定是否成功声纳浮标
yanzheng=link_text>评价
(2) 再到config包内配置查元素的py包(注意是config包内创建!)
创建jw_findelement.py ⽂件 (⼯具类:直接复制,不做修改即可!)封装了各种selenium查元素的各种⽅式
源码如下: