chromedriver:v3.1
自动化测试基础
1、软件测试分类
根据项目流程:单元测试(编码)、集成测试(设计)、系统测试(需求)、验收测试
根据代码是否可见:白盒测试、黑盒测试、灰盒测试
功能测试:逻辑功能测试、界面测试、易用性测试、安装测试、兼容性测试
性能测试:负载测试、压力测试
手工测试:手工执行测试用例
自动化测试:性能自动化和功能自动化
冒烟测试:在对系统进行正式测试之前,先验证主要功能是否实现,是否具备可测性
回归测试:修改代码之后确保没有引入新的错误,或导致其他代码产生错误
随机测试:为了模拟用户的操作,测试中输入的数据都是随机的,以便发现一些边缘性的错误
探索性测试:强调主观能动性,碰到问题时主动改变策略
安全测试:验证产品是否符合安全需求定义和产品质量标准
2、什么项目适合自动化
1)项目需求变动不频繁(回归测试,每日构建后的测试验证)
2)项目周期长
3)自动化测试脚本可复用
3、自动化测试分类和工具
1)分类:UI自动化、接口自动化、单元测试自动化
2)工具:
QTP:企业级自动化测试工具,支持B/S,C/S架构
robot framework:Python语言编写,支持关键字驱动,分布式测试
Watir:基于web模式的功能自动化测试工具
selenium:支持多语言、多平台、多浏览器
4、selenium工具
1)特点:多语言—Java、Python、PHP、ruby
多平台—Windows、Linux、Mac
多浏览器----Firefox、chrome、IE
开源、免费
简单、灵活
2)selenium1.0
selenium IDE:实现浏览器操作的简单录制和回放,支持多种语言
selenium Grid:自动化测试辅助工具
并行执行
通过一个主机控制用例在不同环境、不同浏览器下执行
selenium RC:selenium的核心,支持多种编程语言编写脚本,通过selenium服务器作为代理服务器去访问应用,从而实现测试的目的。
selenium RC:client libraries—编写测试脚本,控制selenium server的库
selenium server—控制浏览器行为
selenium server:selenium core—一堆js函数,嵌入到浏览器中,通过这些函数控制浏览器操作
launcher—启动浏览器,并将selenium core加载到浏览器中,将selenium server的http proxy设置为浏览器的代理服务器
3)selenium2.0
webdriver替代了selenium RC,为了向下兼容性,selenium RC仍然可以使用
selenium RC通过嵌入到浏览器中的js函数操作
webdriver针对各浏览器开发,通过原生浏览器支持或者浏览器扩展控制浏览器
简单自动化测试脚本
Python webdriver API
1、浏览器操作
1)浏览器最大化
driver.maximize_window()
2)设置浏览器宽和高
driver.set_window_size(400,800)
3)控制浏览器前进、后退
driver.forward()
driver.back()
2、简单对象的定位
find_element_by_id()----唯一
find_element_by_name()----唯一
find_element_by_linx_text()----操作对象是文字超链接
find_element_by_partial_link_text()----操作对象是文字超链接
find_element_by_class_name()
find_element_by_tag_name()
find_element_by_xpath()
暂时可以通过firepath定位xpath路径,以后再研究
find_element_by_css_selector()
这个真的不懂,firebug里面可以定位
3、操作测试对象
clear()---------------清除内容,如默认用户名和密码
click()-------------- 模拟鼠标点击操作
send_keys()------向输入框输入
submit()------------提交表单
4、WebElement接口常用方法
size--------------------返回元素尺寸
text----------------------获取元素文本信息
get_attribute(name)-------------获取元素某个属性值
is_displayde-----------------------该元素用户是否可见
5、鼠标事件
ActionChains类操作鼠标事件
ActionChains的使用
from selenium.webdriver.common.actionchains import ActionChains
ActionChains的执行原理
调用ActionChains方法的时候,用户行为不会立刻执行,而是将所有操作放在一个队列中,当执行perform()方法时,按照放入队列的顺序先进先出执行
ActionChains方法的书写格式
ActionChains(driver).context_click(操作对象).perform()
鼠标点击
context_click()------------------鼠标右击
double_click()------------------鼠标双击(应用场景:查看图片,双击选定文字)
click()-----------------------------鼠标点击
click_and_hold()---------------按住鼠标左键不懂
鼠标移动
move_to_element(目标元素)------------------------移动到某个元素
move_by_offset(xoffset,yoffset)--------------------移动到某个坐标
鼠标拖曳
drag_and_drop(source,target)------将元素从起点source移动到终点target
drag_and_drop_by_offset(source,xoffset,yoffset)-------按照坐标移动
6、键盘事件
Keys类操作键盘事件
Keys类的使用
from selenium.webdriver.common.keys import Keys
常用的组合键
send_keys(Keys.CONTROL,‘a’)----------------全选
send_keys(Keys.CONTROL,‘c’)----------------复制
send_keys(Keys.CONTROL,‘v’)----------------粘贴
send_keys(Keys.CONTROL,‘x’)----------------剪切
常用的非组合键
send_keys(Keys.ENTER)--------------------------------回车键
send_keys(Keys.BACK_SPACE)----------------------删除键
send_keys(Keys.SPACE)--------------------------------空格键
send_keys(Keys.TAB)------------------------------------制表键
send_keys(Keys.ESCAPE)------------------------------回退键
send_keys(Keys.F5)---------------------------------------刷新键
7、获得页面URL和title
1)获得当前页面title,判断页面跳转是否符合预期
title = driver.title
2)获得当前URL,一般用来测试重定向
url = driver.current_url
8、设置等待时间
sleep():设置固定休眠时间。Python的time包提供sleep方法
implicitly_wait():webdriver提供的一个隐性等待的时间,在一个时间段内只能的等待,超时则抛出异常
WebDriverWait():webdriver提供的另一个方法,在设置时间内,默认每隔一段时间去检测页面元素是否存在,如果超出设置时间检测不到则抛出异常。
WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
driver - WebDriver 的驱动程序(Ie, Firefox, Chrome 或远程)
timeout - 最长超时时间,默认以秒为单位
poll_frequency - 休眠时间的间隔(步长)时间,默认为0.5 秒
ignored_exceptions - 超时后的异常信息,默认情况下抛NoSuchElementException 异常。
9、定位一组对象
find_elements返回的是一个list
定位一组对象,一般应用于下列场景:
批量操作对象,比如将页面上的CheckBox都选上
1)find_elements_by_tag_name()
2)find_element_by_css_selector()
10、定位frame中的对象
针对frame嵌套的情况,使用switch_to.frame(id/name/xpath)切换到被嵌套的frame中
11、多窗口处理
要想在多个窗口之间切换,首先要获得每一个窗口的唯一标识符号(句柄)。通过获得的句柄来区别分不同的窗口,从而对不同窗口上的元素进行操作
driver.current_window_handle----------------------获得当前窗口的句柄
driver.window_handles--------------------------------获得所有窗口的句柄
driver.switch_to_handle(“句柄”)---------------------切换回句柄所属的窗口
driver.close()---------------------------------------------关闭当前窗口
driver.quit()-----------------------------------------------关闭所有窗口
12、下拉菜单处理
1)传统下拉菜单
先定位到下拉菜单,再点击选项
2)下拉菜单需点击才能显示选项
有两次点击动作,第一次点击下拉菜单,第二次点击选项
3)下拉菜单不需点击,鼠标放上去就会显示选项,则可以使用move_to_element()方法定位
4)针对下拉菜单标签是select的
导入Select类:from selenium.webdriver.support.select import Select
使用方法:Select(driver.find_element_by_name(“xxx”)).select_by_index()
选择列表:
select_by_index(index)---------------------------根据index属性定位选项,index从0开始
select_by_value(value)---------------------------根据value属性定位
select_by_visible_text(text)----------------------根据选项文本值来定位
first_selected_option()----------------------------选择第一个选项
清除列表
deselect_by_index(index)---------------------------根据index属性清除选定的选项,index从0开始
deselect_by_value(value)---------------------------根据value属性
deselect_by_visible_text(text)----------------------根据选项文本值
deselect_all()--------------------------------------------清除所有选项
13、上传文件
上传过程一般是打开一个系统的window窗口,从窗口选择文件添加,一般会卡在如何操作Window窗口。其实,没那么复杂,只要定位上传按钮,通过send_keys()添加文件路径就可以了。
上传控件标签为input
上传控件标签为非input
可以借助第三方工具:Autolt
14、下载文件
webdriver允许设置默认下载路径,从而可以跳过下载弹窗提示
1)chrome下载
思路:实例化一个option对象
设置配置,并加载到option中
启动浏览器,点击下载链接
优势:使用谷歌浏览器下载,不需要针对各种文件类型进行配置
2)Firefox下载
对于Firefox,需要我们设置其Profile:
browser.download.dir:指定下载路径
browser.download.folderList:设置成2表示使用自定义下载路径;设置成0表示下载到桌面;设置成1表示下载到默认路径
browser.download.manager.showWhenStarting:在开始下载时是否显示下载管理器
browser.helperApps.neverAsk.saveToDisk:对所给出文件类型不再弹出框进行询问
Firefox需要针对每种文件类型进行设置,这里需要我们查询对应文件的MIME类型,可以用以下链接进行查询:MIME 参考手册
15、调用js和控制浏览器滚动条
1)webdriver提供了execute_script(script,*args)方法调用js
2)控制浏览器滚动条
应用场景:判断法律文件是否阅读完,滚动条拉倒最下面,表示用户已看完
要操作的元素不在视觉范围内,需要拖动滚动条
火狐浏览器
谷歌浏览器
16、处理cookie
driver.get_cookies()-------------------------------获得所有cookie
driver.get_cookie(name)-------------------------获得name属性的cookie
driver.add_cookie(cookie_dic)-----------------添加cookie(cookie格式为字典,)
driver.delete_cookie(name)---------------------删除特定cookie
driver.delete_all_cookies()----------------------删除所有cookie
17、验证码问题
跳过验证码的方法:
1)去掉验证码
2)设置万能码
做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。
别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。
我先来介绍一下这些东西怎么用,文末抱走。
(1)Python所有方向的学习路线(新版)
这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
最近我才对这些路线做了一下新的更新,知识体系更全面了。
(2)Python学习视频
包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。
(3)100多个练手项目
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。
(4)200多本电子书
这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。
基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。
(5)Python知识点汇总
知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。
(6)其他资料
还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。
这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!