pythonselenium自动化使用教程(selenium python 实现基本自动化测试的示例代码)
pythonselenium自动化使用教程
selenium python 实现基本自动化测试的示例代码安装selenium
打开命令控制符输入:pip install -u selenium
火狐浏览器安装firebug:www.firebug.com,调试所有网站语言,调试功能
selenium ide 是嵌入到firefox 浏览器中的一个插件,实现简单的浏览器操 作的录制与回放功能,ide 录制的脚本可以可以转换成多种语言,从而帮助我们快速的开发脚本,下载地址:https://addons.mozilla.org/en-us/firefox/addon/selenium-ide/
如何使用ide录制脚本:点击seleniumide——点击录制——开始录制——录制完成后点击文件export test case——python/unittest/webdriver——保存;
安装python
安装的时候,推荐选择“add exe to path”,将会自动添加python的程序到环境变量中。然后可以在命令行输入 python -v 检测安装的python版本。
浏览器内壳:ie、chrome、firefox、safari
1、webdriver:用unittest框架写自动化用例(setup:前置条件,teardown清场)
|
import unittest from selenium import webdriver class ranzhi(unittest.testcase): def setup( self ): self .driver = webdriver.firefox() #选择火狐浏览器 def test_ranzhi( self ): pass def teardown( self ): self .driver.quit() #退出浏览器 |
2、断言,检查跳转的网页是否和实际一致
断言网址时需注意是否为伪静态(path_info)或者get,前者采用路径传参数(sys/user-creat.html),后者通过字符查询传参数(sys/index.php?m=user&f=index)
当采用不同方式校验网址会发现变化。
|
self .assertequal( "http://localhost:8080/ranzhi/www/s/index.php?m=index&f=index" , self .driver.current_url, "登录跳转失败" ) |
3、定位元素,在html里面,元素具有各种各样的属性。我们可以通过这样唯一区别其他元素的属性来定位到这个元素.
webdriver提供了一系列的元素定位方法。常见的有以下几种:id,name,link text,partial link text,xpath,css seletor,class,tag.
|
self .driver.find_element_by_xpath( '//*[@id="s-menu-superadmin"]/button' ).click() self .driver.find_element_by_id( 'account' ).send_keys( 'admin' ) self .driver.find_element_by_link_text(u '退出' ).click() |
定位元素需注意的问题:
a.时间不够,采用两种方式(self.implicitly_wait(30),sleep(2))
b.函数嵌套(<iframe></iframe>)
|
# 进入嵌套 self .driver.switch_to.frame( 'iframe-superadmin' ) #退出嵌套 self .driver.switch_to.default_content() |
c.flash,验证码(关闭验证码或使用万能码)
d.xpath问题:最好采用最简xpath,当xpath中出现li[10]等时需注意,有时页面定位会出现问题
4、采用csv存数据
csv:以纯文本形式存储表格数据(数字和文本),csv文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符。大量程序都支持某种csv变体,至少是作为一种可选择的输入/输出格式。
|
melody101,melody101,m, 1 , 3 , 123456 ,@qq.com melody102,melody101,f, 2 , 5 , 123456 ,@qq.com melody103,melody101,m, 3 , 2 , 123456 ,@qq.com |
|
import csv # 读取csv文件到user_list字典类型变量中 user_list = csv.reader( open ( "list_to_user.csv" , "r" )) # 遍历整个user_list for user in user_list: sleep( 2 ) self .logn_in( 'admin' , 'admin' ) sleep( 2 ) # 读取一行csv,并分别赋值到user_to_add 中 user_to_add = { 'account' : user[ 0 ], 'realname' : user[ 1 ], 'gender' : user[ 2 ], 'dept' : user[ 3 ], 'role' : user[ 4 ], 'password' : user[ 5 ], 'email' : user[ 0 ] + user[ 6 ]} self .add_user(user_to_add) |
5、对下拉列表的定位采用select标签
|
from selenium.webdriver.support.select import select # 选择部门 dp = self .driver.find_element_by_id( 'dept' ) select(dp).select_by_index(user[ 'dept' ]) # 选择角色 select( self .driver.find_element_by_id( 'role' )).select_by_index(user[ 'role' ]) |
6、模块化代码
需要对自动化重复编写的脚本进行重构(refactor),将重复的脚本抽取出来,放到指定的代码文件中,作为共用的功能模块。使用模块化代码注意需倒入该代码。
|
#模块化代码后引用,需导入代码模块 from ranzhi_lib import ranzhilib self .lib = ranzhilib( self .driver) # 点击后台管理 self .lib.click_admin_app() sleep( 2 ) # 点击添加用户 self .lib.click_add_user() # 添加用户 self .lib.add_user(user_to_add) sleep( 1 ) # 退出 self .lib.logn_out() sleep( 2 ) |
|
class ranzhilib(): # 构造方法 def __init__( self , driver): self .driver = driver |
7、自定义函数运行的先后顺序:完整的单元测试很少只执行一个测试用例,开发人员通常都需要编写多个测试用例才能对某一软件功能进行比较完整的测试,这些相关的测试用例称为一个测试用例集,在pyunit中是用testsuite类来表示,采用unittest.testsuite()。
pyunit使用testrunner类作为测试用例的基本执行环境,来驱动整个单元测试过程。python开发人员在进行单元测试时一般不直接使用testrunner类,而是使用其子类texttestrunner来完成测试。
|
# 构造测试集 suite = unittest.testsuite() suite.addtest(ranzhitest( "test_login" )) suite.addtest(ranzhitest( "test_ranzhi" )) # 执行测试 runner = unittest.texttestrunner() runner.run(suite) |
以下代码为登录“然之系统”,进入添加用户,循环添加用户并检测添加成功,再退出的过程。以下程序分别为主程序,模块化程序,执行程序,csv文件
|
import csv import unittest from time import sleep from selenium import webdriver # 模块化代码后引用需导入代码模块 from ranzhi_lib import ranzhilib class ranzhi(unittest.testcase): def setup( self ): self .driver = webdriver.firefox() self .lib = ranzhilib( self .driver) # 主函数 def test_ranzhi( self ): # 读取csv文件到user_list字典类型变量中 user_list = csv.reader( open ( "list_to_user.csv" , "r" )) # 遍历整个user_list for user in user_list: sleep( 2 ) self .lib.logn_in( 'admin' , 'admin' ) sleep( 2 ) # 断言 self .assertequal( "http://localhost:8080/ranzhi/www/sys/index.html" , self .driver.current_url, '登录跳转失败' ) # 读取一行csv,并分别赋值到user_to_add 中 user_to_add = { 'account' : user[ 0 ], 'realname' : user[ 1 ], 'gender' : user[ 2 ], 'dept' : user[ 3 ], 'role' : user[ 4 ], 'password' : user[ 5 ], 'email' : user[ 0 ] + user[ 6 ]} # 点击后台管理 self .lib.click_admin_app() # 进入嵌套 self .lib.driver.switch_to.frame( 'iframe-superadmin' ) sleep( 2 ) # 点击添加用户 self .lib.click_add_user() # 添加用户 self .lib.add_user(user_to_add) # 退出嵌套 self .driver.switch_to.default_content() sleep( 1 ) # 退出 self .lib.logn_out() sleep( 2 ) # 用新账号登录 self .lib.logn_in(user_to_add[ 'account' ], user_to_add[ 'password' ]) sleep( 2 ) self .lib.logn_out() sleep( 2 ) def teardown( self ): self .driver.quit() |
|
from time import sleep from selenium.webdriver.support.select import select class ranzhilib(): # 构造方法 def __init__( self , driver): self .driver = driver # 模块化添加用户 def add_user( self , user): driver = self .driver # 添加用户名 ac = driver.find_element_by_id( 'account' ) ac.send_keys(user[ 'account' ]) # 真实姓名 rn = driver.find_element_by_id( 'realname' ) rn.clear() rn.send_keys(user[ 'realname' ]) # 选择性别 if user[ 'gender' ] = = 'm' : driver.find_element_by_id( 'gender2' ).click() elif user[ 'gender' ] = = 'f' : driver.find_element_by_id( 'gender1' ).click() # 选择部门 dp = driver.find_element_by_id( 'dept' ) select(dp).select_by_index(user[ 'dept' ]) # 选择角色 role = driver.find_element_by_id( 'role' ) select(role).select_by_index(user[ 'role' ]) # 输入密码 pwd1 = driver.find_element_by_id( 'password1' ) pwd1.clear() pwd1.send_keys(user[ 'password' ]) pwd2 = driver.find_element_by_id( 'password2' ) pwd2.send_keys(user[ 'password' ]) # 输入邮箱 em = driver.find_element_by_id( 'email' ) em.send_keys(user[ 'email' ]) # 点击保存 driver.find_element_by_id( 'submit' ).click() sleep( 2 ) # 登录账号 def logn_in( self , name, password): driver = self .driver driver.get( 'http://localhost:8080/ranzhi/www' ) sleep( 2 ) driver.find_element_by_id( 'account' ).clear() driver.find_element_by_id( 'account' ).send_keys(name) driver.find_element_by_id( 'password' ).clear() driver.find_element_by_id( 'password' ).send_keys(password) driver.find_element_by_id( 'submit' ).click() sleep( 2 ) # 退出账号 def logn_out( self ): self .driver.find_element_by_id( 'start' ).click() sleep( 4 ) self .driver.find_element_by_link_text(u '退出' ).click() sleep( 3 ) # 点击后台管理 def click_admin_app( self ): self .driver.find_element_by_xpath( '//*[@id="s-menu-superadmin"]/button' ).click() sleep( 1 ) def click_add_user( self ): self .driver.find_element_by_xpath( '//*[@id="shortcutbox"]/li/li[1]/li/a/h3' ).click() sleep( 3 ) |
|
import unittest from ranzhi import ranzhi class ranzhitestrunner(): def run_tests( self ): suite = unittest.testsuite() suite.addtest(ranzhi( 'test_ranzhi' )) runner = unittest.texttestrunner() runner.run(suite) if __name__ = = "__main__" : ranzhi_test_runner = ranzhitestrunner() ranzhi_test_runner.run_tests() |
|
melody109,melody101,m, 1 , 3 , 123456 ,@qq.com melody106,melody101,f, 2 , 5 , 123456 ,@qq.com melody107,melody101,m, 3 , 2 , 123456 ,@qq.com |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://www.cnblogs.com/melodylin/p/5656185.html
- python编程中冒号的用法(浅谈python中get pass用法)
- python 二叉树的深度遍历(python 将有序数组转换为二叉树的方法)
- python绘折线图数据(python2.7使用plotly绘制本地散点图和折线图)
- python中三种基本的数值类型(python基础知识一变量与简单数据类型详解)
- python定时推送邮件(python实现定时压缩指定文件夹发送邮件)
- python起源详解(Python发展简史 Python来历)
- python查找含特定字符的字符串(Python实现查找字符串数组最长公共前缀示例)
- python mysql配置(详解python校验SQL脚本命名规则)
- python爬虫经典步骤(详解python爬虫系列之初识爬虫)
- python处理水印(Yii 使用intervention/image拓展实现图像处理功能)
- python scrapy 框架原理(一步步教你用python的scrapy编写一个爬虫)
- python批量转换图片格式(利用Python对文件夹下图片数据进行批量改名的代码实例)
- python基础教学之125 装饰器简介(python3 property装饰器实现原理与用法示例)
- ubuntu python3.7安装(详解Ubuntu16.04安装Python3.7及其pip3并切换为默认版本)
- python 验证码识别模块([机器视觉]使用python自动识别验证码详解)
- python成绩判断系统(Python根据成绩分析系统浅析)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
- 节日我在岗|警景相融 平安相伴(节日我在岗警景相融)
- 战 疫 时刻 致敬每一位石化大学的 守护者(战疫时刻)
- 老弄堂里的市井味道(老弄堂里的市井味道)
- 小米音乐可绑定QQ音乐, QQ音乐 真的会消失在小米的设备上吗(小米音乐可绑定QQ音乐)
热门推荐
- typedef和var有什么不同(TypeScrip中泛型的案例详解)
- numpy如何获取索引(NumPy 基本切片和索引的具体使用方法)
- python电脑自动发送邮件(python学习--使用QQ邮箱发送邮件代码实例)
- $(document).ready和window.onload的区别
- python基于django的博客系统(利用django+wechat-python-sdk 创建微信服务器接入的方法)
- parseInt()和parseFloat()
- python如何抓取公众号文章(python爬取微信公众号文章的方法)
- php验证码初始化教程交流(PHP token验证生成原理实例分析)
- mysql的三种模式(详解 MySQL的FreeList机制)
- mysql8.0关键字段使用(MySQL 8.0新特性之隐藏字段的深入讲解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9