UI自动化测试01

应用场景

前端简介

三大技术:HTML,超文本标记语言,编写页面元素。了解常用的标签,掌握元素的核心属性(id、name、class):绿叶学习网

CSS,层叠样式表,负责页面的表示美化,掌握常用的选择器。

JS,JavaScript,负责页面行为,掌握如何获取元素。

selenium:安装selenium    pip install selenium

webdriver原理

基本使用:

webdriver api

浏览器操作:

打开

关闭:quit()关闭整个浏览器,close()关闭当前窗口。

窗口尺寸:driver.maximize_window,浏览器最大化

                  driver.minimize_window,浏览器最小化

                  set_window_size(w,h),自定义大小

刷新:refresh()

前进:forward()

后退:back()

获取页面标题:title

获取页面URL:current_url

获取页面源码:page_source

元素定位

第一种.模块:By

from selenium.webdriver.common.by import By

方法:

find_element(By.mode,value),返回一个元素,如果未找到则报异常

find_elements(By.mode,value),以列表返回一组元素,如果未找到则返回空列表

mode,指定定位元素的方式:

ID,通过元素的id属性值定位

NAME,通过元素的name属性值定位

CLASS_NAME,通过元素的class属性值定位

LINK_TEXT,通过元素的文本值定位

PATRIAL_LINK_TEXT,通过元素的部分文本值定位

TAG_NAME,通过元素的标签名定位

CSS_SELECTOR,通过元素在HTML页面中的位置定位,使用CSS定位

XPATH,通过元素在HTML页面中的位置定位,使用xpath定位

第二种

方法:

find_element_by_mode(value),返回一个元素,如果未找到则报异常

find_elements_by_mode(value),以列表返回一组元素,如果未找到则返回空列表

mode,指定定位元素的方式:

id,通过元素的id属性值定位

name,通过元素的name属性值定位

class_name,通过元素的class属性值定位

link_text,通过元素的文本值定位

patrial_link_text,通过元素的部分文本值定位

tag_name,通过元素的标签名定位

css-selector,通过元素在HTML页面中的位置定位,使用CSS定位

xpath,通过元素在HTML页面中的位置定位,使用xpath定位

        高级用法:

 

元素操作

click(),鼠标单击

send-keys(value),输入

clear(),清空

text,获取元素文本

get_attribute(obj),获取元素指定属性的值

find_element(),定位子元素

如:获取所有类名为nbg的标签

res = driver.find_element(By.CLASS_NAME,'nbg')

等待

强制等待:time下的sleep()方法

隐式等待:implicitly_wait(t):在指定的时间t内等待页面加载完成,如果加载完成的时间小于t,剩余时间(t-加载时间)就不再等待;如果在时间t内未加载完成则报错。

作用范围:全局

显示等待:WebDriverWait()

导入:from selenium.webdriver.support.ui import WebDriverWait

可以看作是特殊的隐式等待:在指定的时间t内等待指定元素加载完成,如果加载完成的时间小于t,剩余时间(t-加载时间)就不再等待;如果在时间t内未加载完成则报错。

方法:WebDriverWait(driver,timeout,poll_frequency)

driver:浏览器对象

timeout:超时时间

poll_frequency:扫描间隔时间,一般是0.5s

后面接一个.until(element):用于指定加载的元素

截图

save_screenshot(file)

file:路径和文件名(./截图_1.png)

get_screenshot_as_file(file)

浏览器多窗口管理

原理:在浏览器中,每一个打开的窗口都有一个唯一的标识,叫做句柄。通过句柄可以实现在不同窗口间的切换。

方法:

current_window_handle,获取当前窗口的句柄

window_handles,获取已经打开的所有窗口的句柄

switch_to.window(handle),通过指定句柄,切换窗口

多框架处理

原理:在HTML中,由于iframe标签可以实现一个内嵌框架。内嵌框架,说白了就是在当前页面再嵌入另外一个页面。通过webdriver打开页面后,默认指向最外层框架,如果需要要操作的元素在内层框架,则需要定位内层框架,并能切换到内层框架后操作。

方法:

switch_to.frame(f),切换到指定框架,f为定位到的iframe标签

switch_to.default_content(),切换到最外层框架

switch_to.parent_frame(),切换到上层框架

调用JS代码

方法:execute_script(js)

 给只读属性的元素赋值

通过JS代码获取:

js=‘document.getElementById(“childdate”).value="2009-10-10",’

driver.execute_script(js)

警告框管理

类型:

alert:只有确定按钮

confirm:有确定和取消按钮

prompt:可以输入内容

方法:

switch_to.alert.text,获取警告框中的文本信息

switch_to.alert.accept(),在警告框中点击确定

switch_to.alert.dismiss(),在警告框中点击取消

switch_to.alert.send_keys(value),在警告框中输入内容

下拉框处理

模块:Select

from selenium.webdriver.support.select import Select

使用:

1.定义下拉框,假设为s

2.选择下拉框中的选项:Select(s).方法

方法:

options,返回下拉框中的所有选项

select_by_index(),通过索引选择

select_by_value(),通过value属性值选择

select_by_visible_text(),通过选项的文本值选择

POM:实现页面与测试用例分离,从而提高代码的可读性,可维护性

页面基类:封装页面上元素操作的相应方法(实现对webdriver api的二次封装),是所有页面类的父类。

页面类:继承页面基类,主要封装与业务流程相关元素的操作方法

基于协议的接口测试

HTTP连接 :get请求

HTTP连接:post请求

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值