自动化框架主要的核心框架就是分层+PO模式:分别为:基础封装层BasePage,PO页面对象层,TestCase测试用例层。然后再加上日志处理模块,ini配置文件读取模块,unittest+ddt数据驱动模块,jenkins持续集成模式组成。
需求稳定,不会频繁变更。
研发和测试周期长,需要频繁执行回归测试。
需要在多种平台上重复运行相同测试的场景。
某些测试项目,通过手工测试无法实现,或者手工成本太高。
被测软件的开发较为规范,能够保证系统的可测试行
编写自动化测试计划
设计自动化测试用例
编写自动化测试框架和脚本
调试并维护脚本
无人值守测试
后期脚本维护(添加用例、开发更新版本)
在开发的时候就已经将大部分的bug解决了,所以使用中并不多
不多,因为之前项目组是把已经测试通过的基本功能再进行自动化脚本编写和在后续版本执行自动化测试,它主要是保证已经测试通过的功能在新版本更新后没有问题。
引用自动化测试之后,能代替大量繁琐的回归测试工作
把业务测试人员解放出来,让业务测试人员把精力集中在复杂的业务功能模块上
自动化测试一般是对稳定下来的功能进行自动化,保证不会因为产品的更新导致之前稳定下来的功能出现BUG
有误报过,有时候自动化测试报告中显示发现了bug,实际去通过手工测试去确认又不存在该bug。
误报原因一般是:
元素定位不稳定,需要尽量提高脚本的稳定性;
开发更新了页面但是测试没有及时更新维护!
频繁地变更页面,经常要修改页面对象类里面的代码
自动化测试偶尔出现过误报
自动化测试结果出现覆盖的情况:Jenkins根据时间建立文件夹
自动化测试代码维护比较麻烦
自动化测试进行数据库对比数据
可以说出以下自己擅长的一种:
python+selenium+unittest
python+selenium+pytest
主要是冒烟测试和回归测试。回归测试主要写一些功能稳定的场景,通过自动化手段去实现,节约测试时间。
因为自动化测试用例也是在不断的更新和迭代,没有刻意去统计,大概在30%-40%左右
主要是用selenium driver.execute_script()方法,来修改js的元素
利用javaScript去修改当前元素的边框样式来到达高亮显示的效果,
页面加载元素过慢,添加等待时间
页面有frame框架页,需要先跳转入frame框架再定位
driver.switch_to.frame()
可能该元素是动态元素,定位方式要优化,可以使用部分元素定位或通过父节点或兄弟节点定位。
可能识别了元素,但是不能操作,比如元素不可用,不可写等。需要使用js先把前置的操作完成,
ID,Name,Class_name,Tag_name.Link_text,Xpath,CSS
先用driver.switch_to.frame()跳转进去frame,然后再操作页面元素,操作完后使用driver.swith_to.default_content()跳转出来
###需要先定位到alert元素,点击之后
使用driver.switch_to.alert方法先跳转到alert弹出窗口
然后再通过accept点击确定按钮,通过dismiss点击取消难,通过text()获得弹出窗口的文本。
我们常见的alert弹窗有两种:基于windows弹窗和基于web页面弹窗
webdriver是能够处理alert弹窗的,Selenium提供了Alert这个接口。
相关操作代码如下:
Alert alert = driver.switchTo().alert() // 切换到Alert
alert.accept() // 点击弹窗上确定按钮
alert.dismiss() // 点击弹窗的取消按钮
alert.getText() // 获取弹窗上的文本文字内容
alert.sendkeys() // 有些弹窗还支持文本输入,这个可以把要输入字符通过sendkeys方法输入
多窗口之间跳转处理,我们在项目中也经常遇到。就是,当你点击一个链接,这个链接会在一个新的tab打开,然后你接下来要在新tab打开的页面查找元素,
我们在点击链接前使用driver.current_window_handle获得当前窗口句柄。
再点击链接。点击后通过driver.window_handles获得所有窗口的句柄, 然后再循环找到新窗口的句柄,然后再通过driver.switch_to.window()方法跳转到新的窗口。
定位元素后:分别通过isEnabled(),isSelected(),isDisplayed()三个方法进行判断。
在Selenium中有一个叫Select的类,这个类支持对下拉菜单进行操作。使用方法如下:
定位元素
把定位的元素转化成Select对象。
sel = Select(定位的元素对象)
通过下标或者值或者文本选中下拉框。
sel.select_by_index(index);
sel.select_by_value(value);
sel.select_by_visible_text(text);
首先要分析当前网页使用日历插件的前端代码,看看能不能通过元素定位,点击日期实现,如果不能,可能需要借助javascript。
还有些日历控件一个文本输入框,可以直接sendKeys()方法来实现传入一个时间的数据。
常见的selenium异常有这些:
NoSuchElementException:没有该元素异常
TimeoutException :超时异常
ElementNotVisibleException :元素不可见异常
NoSuchAttributeException :没有这样属性异常
NoSuchFrameException :没有该frame异常
简单来说,两个都可以实现退出浏览器session功能,close是关闭你当前聚焦的tab页面,而quit是关闭全部浏览器tab页面,并退出浏览器session。
quit一般用在结束测试之前的操作,close用在执行用例过程中关闭某一个页面的操作
在Selenium中提供了一个get_screenshot_as_file()的方法来截图的,一般结合try/except捕获异常时使用,进行错误截图
#官网的最新方法
driver.save_screenshot(’./image.png’)
定位元素后,直接使用send_keys()方法设置就行,参数为需要上传的文件的路径。
线程等待(强制等待)如time.sleep(2):线程强制休眠2秒钟,2秒过后,再执行后续的代码。建议少用。
imlicitlyWait(隐式等待)会在指定的时间范围内不断的查找元素,直到找到元素或超时,特点是必须等待整个页面加载完成。
WebDriverWait(显式等待)通常是我们自定义的一个函数代码,这段代码用来等待某个元素加载完成,再继续执行后续的代码
在Webdriver中,处理键盘事件和鼠标事件,一般使用Actions类提供的方法,包括鼠标悬停,拖拽和组合键输入。
这里介绍几个方法
方法:clickAndHold()
使用场景:找到一个元素,点击鼠标左键,不放手。自己可以点击鼠标不松开试试这个场景。
方法:contentClick()
使用场景:模拟鼠标右键点击,一般右键会带出菜单来。
方法:doubelClick()
使用场景:模拟鼠标双击
方法:dragAndDrop(source,target)
使用场景:模拟从source这个位置,拖拽一个元素到target位置
键盘事件方法:keyDown(keys.ALT), keyUp(keys.SHIFT)
使用场景:点击键盘事件,分为两个动作,一个点击键盘,第二个动作是释放点击(松开)
断言assert 用于代码中验证实际结果符合预期结果,如果测试用例失败,则抛出异常并且提供断言日志
UI自动化:又分为web和和app自动化 (web自动化(selenium)app自动化(appium))
接口自动化
cookie 全局变量 反射
存储到excel表,需要时再取
框架里边的期望结果:查库依赖用户成功之后
较unittest,pytest有以下优点
自动发现测试模块、测试方法
断言使用asert+表达式
可以设置会话级、模块级、类级、函数级的fixtures、数据准备+清理工作
有丰富的插件库,目前在300个以上。
GET - 从指定的资源请求数据。请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数用&连接
POST - 向指定的资源提交要被处理的数据。POST请求会把请求的数据放置在HTTP请求包的包体中
post对数据进行加密更加安全,且可以包含更大的数据
HTTPS 协议需要到 CA (Certificate Authority,证书颁发机构)申请证书,一般免费证书较少,因而需要一定费用。(以前的网易官网是http,而网易邮箱是 https)
HTTP 是超文本传输协议,信息是明文传输,HTTPS 则是具有安全性的 SSL 加密传输协议。
HTTP 和 HTTPS 使用的是完全不同的连接方式,用的端口也不一样,前者是80,后者是443。
HTTP 的连接很简单,是无状态的。HTTPS 协议是由 SSL+HTTP 协议构建的可进行加密传输、身份认证的网络协议,比 HTTP 协议安全。(无状态的意思是其数据包的发送、传输和接收都是相互独立的。无连接的意思是指通信双方都不长久的维持对方的任何信息)
cookie:在客户端存储在客户端用于存储会话信息的
session:在服务器端,记录用户的请求状态,一般默认时间30min
session_id会存在cookie中,每次请求cookie中所有信息都会传递给服务器,服务器通过 session_id来识别是否是同一个用户请求,不是同一个用户的话,就会要求重新登录
token:访问权限
鉴权:访问的接口是否正常,是否非法访问绕过前端。防止跳过页面直接访问接口。token授权:是否具有访问接口的权限。唯一全局动态的 key
不稳定
可靠性
不易维护
成本与收益
Selenium不支持桌面软件的自动化测试,Selenium是根据网页元素的属性才定位元素,而其他桌面软件自动化测试工具是根据桌面元素的位置来定位元素,当然现在也有根据桌面元素的属性来定位的。
#可以使用pyautogui来实现桌面自动化
UI自动化的目的不是为了发现多少Bug,主要是为了减轻重复的基础操作和线上监控的作用
1.添加元素智能等待时间 driver.implicitly_wait(30)
2.添加强制等待时间 time.sleep()
3.try 方式进行id,name,clas,x path, css selector不同方式进行定位,如 果第一种失败可以自动尝试第二种
context_click() 右击 --> 此方法模拟鼠标右键点击效果
double_click() 双击 --> 此方法模拟双标双击效果
drag_and_drop() 拖动 --> 此方法模拟双标拖动效果
move_to_element() 悬停 --> 此方法模拟鼠标悬停效果
perform() 执行 --> 此方法用来执行以上所有鼠标方法
send_keys(Keys.BACK_SPACE) 删除键(BackSpace)
send_keys(Keys.SPACE) 空格键(Space)
send_keys(Keys.TAB) 制表键(Tab)
send_keys(Keys.ESCAPE) 回退键(Esc)
send_keys(Keys.ENTER) 回车键(Enter)
send_keys(Keys.CONTROL,‘a’) 全选(Ctrl+A)
send_keys(Keys.CONTROL,‘c’) 复制(Ctrl+C)
send_keys(Keys.CONTROL,‘v’) 全选(Ctrl+V)
send_keys(Keys.CONTROL,‘x’) 复制(Ctrl+X)
提问:最近有在面试,市场怎么样?
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:【文末小卡片领取】
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!