python自动测试模型_python selenium-4自动化测试模型

1.线性测试

特点:每一个脚本都是完整且独立的,可以单独执行。

缺点:用例的开发与维护成本很高

2.模块化驱动测试

特点:把重复的操作独立成公共模块,提高测试用例的可维护性

示例:将搜索封装到func中,其他文件直接导入使用即可

func.py

class Func():

def search(self,driver):

driver.find_element_by_xpath("//input[@id='kw' and @class='s_ipt']").send_keys("hello")

driver.find_element_by_xpath("//input[@value='百度一下' and @id='su']").click()

result_text = driver.find_element_by_xpath("//span[@class='nums_text']").text

assert "百度为您找到相关结果约" in result_text

action.py

import sys

from selenium import webdriver;

from time import sleep

from testcase import func

path = sys.path[0].replace("testcase", "") + "driver/geckodriver"

driver = webdriver.Firefox(executable_path=path)

driver.implicitly_wait(5)

driver.get("http://www.baidu.com")

print("打开百度")

func.Func().search(driver)

#等同于

#s=func.Func()

#s.search(driver)

sleep(3)

driver.quit()

print("退出")

3.数据驱动测试

3.1参数化搜索关键字

func.py

from time import sleep

class Func():

def search(self,driver,word):

driver.find_element_by_xpath("//input[@id='kw' and @class='s_ipt']").clear()

driver.find_element_by_xpath("//input[@id='kw' and @class='s_ipt']").send_keys(word)

driver.find_element_by_xpath("//input[@value='百度一下' and @id='su']").click()

result_text = driver.find_element_by_xpath("//span[@class='nums_text']").text

assert "百度为您找到相关结果约" in result_text

sleep(1)

action.py

import sys

from selenium import webdriver;

from testcase import func

path = sys.path[0].replace("testcase", "") + "driver/geckodriver"

driver = webdriver.Firefox(executable_path=path)

driver.implicitly_wait(5)

driver.get("http://www.baidu.com")

print("打开百度")

func.Func().search(driver,"hello")

func.Func().search(driver,"world")

driver.quit()

print("退出")

3.2读取txt文件

read():读取整个文件

readline():读取一行数据

readlins():读取所有行的数据

word.txt

java,廖雪峰

pyhton,菜鸟

selenium,阮一峰

action.py

import sys

from selenium import webdriver;

from testcase import func

path = sys.path[0].replace("testcase", "") + "driver/geckodriver"

driver = webdriver.Firefox(executable_path=path)

driver.implicitly_wait(5)

driver.get("http://www.baidu.com")

print("打开百度")

file = open("word.txt","r")

lines = file.readlines()

file.close()

for i in lines:

searchWord = i.split(',')[0]

func.Func().search(driver,searchWord)

driver.quit()

print("退出")

3.3读取csv文件

word.csv

#读取csv文件

import csv

data = csv.reader(open("word.csv","r"))

for user in data:

print(user,len(user),len(user[0]))

aciton.py

```#python

import csv

import sys

from selenium import webdriver;

from testcase import func

path = sys.path[0].replace("testcase", "") + "driver/geckodriver"

driver = webdriver.Firefox(executable_path=path)

driver.implicitly_wait(5)

driver.get("http://www.baidu.com")

print("打开百度")

data = csv.reader(open("word.csv",'r'))

for row in data:

if len(row[0])==0:

pass

else:

func.Func().search(driver,row[0])

func.Func().search(driver,row[1])

driver.quit()

print("退出")

## 3.4读取Excel文件

```#python

import xlrd

#打开表格

file = xlrd.open_workbook("word.xlsx")

#获取所有sheet,sheet_names()表名

print(file.sheet_names())

#根据sheet索引或名称获取shell内容

sheet1=file.sheet_by_index(0)

sheet2=file.sheet_by_name("工作表 1 - word")

#获取sheet表格的行数和列数

sheet2_row= sheet2.nrows

sheet2_col= sheet2.ncols

print(sheet2.name,sheet2_row,sheet2_col)

#获取每一行的数据

for i in range(sheet2_row):

print("",sheet2.row_values(i))

#获取每一列的数据

for i in range(sheet2_col):

print(sheet2.col_values(i))

# #获取单元格的数据

print(sheet2.cell(2,1).value,sheet2.cell(2,0).value)

#循环打印非空值

for i in range(sheet2_row):

for j in range(sheet2_col):

if len(sheet2.cell(i,j).value) != 0:

print(sheet2.cell(i,j).value)

import xlrd

import sys

from selenium import webdriver;

from testcase import func

path = sys.path[0].replace("testcase", "") + "driver/geckodriver"

driver = webdriver.Firefox(executable_path=path)

driver.implicitly_wait(5)

driver.get("http://www.baidu.com")

print("打开百度")

data = xlrd.open_workbook("word.xlsx")

sheet2_data=data.sheet_by_index(1)

sheet2_rows=sheet2_data.nrows

sheet2_col=sheet2_data.ncols

for i in range(sheet2_rows):

for j in range(sheet2_col):

if i > 0:

text=sheet2_data.cell(i,j).value

if len(text) > 0:

func.Func().search(driver,text)

driver.quit()

print("退出")

3.5读取xml文件

Windows

Firefox

http://www.baidu.com

北京

广东

深圳

珠海

浙江

杭州

from xml.dom import minidom

dom = minidom.parse('info.xml')

root = dom.documentElement

print(root.nodeName,root.nodeType,root.ELEMENT_NODE)

pros = dom.getElementsByTagName("login")

for pro in pros:

print(pro.getAttribute("username"),pro.getAttribute("password"))

pros = dom.getElementsByTagName("city")

for pro in pros:

print(pro.childNodes[0].data)

#等价于

print(pro.firstChild.data)

4.关键字驱动测试

常用命令篇: 1. Open(url) url可以是相对的,也可以是绝对的 如绝对的url:open(http://www.taobao.com/) 相对的url:open("/search?q=’aa’"); 2. Click(locator) click可以单击一个链接,按钮或者单选框复选框等。 Click系列的有:click、clickAt、clickAndWait、clickAtAndWait clickAt(locator,coordstring): coordstring是需要单击的坐标 3. doubleClick(locator) 双击操作,用户与click一致 4. type(locator,value) 可以为指定位置输入指定值,也可以为单选框和复选框按钮赋值,value是选项的值而不是文本内容 5. typeKeys(locator,value) 模拟用户输入的行为,与type不同的是,type是强行赋值,而typeKeys是完全模拟用户操作,一个键一个键敲上去的。当输入框中原来就有值时,使用type会用新值替换旧值,而typeKeys则是在原来值上进行追加。如,原来值为aaa,现在要输入bbb,使用type则最终值为bbb,使用typeKeys则最终值为aaabbb. 6. focus(locator) 将焦点移动到指定的元素上,如果是一个可输入的元素,则将聚焦到输入框 7. select(locator,option) 选择下列框中的选项,option默认为标签label 如selenium.select (“size_select”,”label=small”),id=size_select 8. selenium.goBack()后退 9. highlight(locator)指定元素高亮 10. refresh()刷新当前页面 11. AssertText(locator,pattern) 验证某个元素的文本值是否与预期值一致,locator为元素定位,pattern为预期值 12. AssertAttribute(attributelocator,pattern) 验证某个元素的某个属性值与预期值是否一致,attributelocator为属性定位,pattern为预期值 13.assertEquals(value,selenium.getAttribute(xpath+"@value")) 验证某个元素的属性值或者是文本值是否与预期值一致 14. assertInPara(remark_para_1, getRemark(engine_type)); 一般用于验证url和remark串 15. mouseOver(locator) 将鼠标停留在某个元素上,locator为元素定位。 16. mouseDown(locator)/mouseUp(locator) 用户在某个元素上按下或者释放鼠标。Locator为元素定位 17. keyDown(locator,keysequence)/ keyUp(locator,keysequence) 用户按下或者释放某一个按钮,Locator为元素定位,keysequence为按键对应的ASCII码 18. indexOf:判断两个字符串是否存在包含关系 若x=”abcd”;y=”bc”;则有X.indexOf(y)==0 若不存在包含关系,则X.indexOf(y)==-1 19. System.out.println(value); 可以向屏幕打印出value值,这个value值可以是元素的属性值或者文本值等 20. selenium.getCookie(); 可以取到当前页面的cookie值 21. selenium.deleteCookie(name,path) 删除cookie值中的某个参数,如下: selenium.deleteCookie("_nk_","path=/, domain=.taobao.com, recurse=true"); 删除_nk_参数,path的格式必须指定上面三个字段,path=/表示当前路径,domain=.taobao.com为改cookie所属的域,recurse=true 22. assertValue(locator,pattern) 验证某个可输入元素是否被赋了某个值 23. selenium.close() 关闭浏览器。 24. contextMenu(locator)打开关联的菜单,与右键作用差不多,但是对弹出的菜单selen
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值