1 总体需要

1.1 实现目标

  • 基于BS架构,模仿用户(鼠标、键盘)操作,达到疾速、反复执行测试用例;
  • 便于回归测试,疾速笼罩主线用例或性能;
  • 线上或线下巡检测试,联合继续集成,及时发现运行环境存在的问题;
  • 晋升集体自动化测试技术能力,为业务提供强有力的测试伎俩。

1.2 性能需要

  • 基于Unittest,封装、调用和组织所有的测试用例,进行批量或指定用例运行;
  • 反对邮件服务,可增加任意团队成员邮箱,及时告诉团队成员自动化运行后果;
  • 反对log日志,保留运行过程所有或须要记录的数据;
  • 反对HTML测试报告,直观展现测试后果和数据;
  • 反对用例设计和测试后果拆散,便于数据管理;
  • 反对Json、conf、excel等配置文件读取,提供灵便的配置文件操作方法;
  • 反对用户登录封装,后续所有的用例登录专用一个办法;
  • 反对任意批改HTMLTestRuner,可定制测试报告模板;
  • 反对测试报告多语言(英文和中文);
  • 反对截图性能;
  • 反对Jenkins继续集成。

1.3 其余要求

  • 实用所有bs架构自动化测试;
  • 模块化设计,我的项目框架模式组织代码;
  • 公共办法封装,对立调用;
  • 数据和后果离开,清晰明了;
  • 反对邮件自定义;
  • 代码正文清晰。

1.4 实用人员

  • 有肯定测试根底的软件测试人员;
  • 有肯定的代码(Python/Java)功底;
  • 致力于学习web UI自动化测试的所有人员。

1.5 学习周期

  • 两个星期到一个月,可达到独立进行web UI自动化测试;

1.6 学习倡议

  • 倡议依照文章程序,一步一步进行学习和实际;
  • 文章是从根本的环境搭建到最终框架齐全搭建的一个过程,相对来说还是比拟具体的;
  • 文章偏差于我的项目实战,未有太多的实践介绍和名词解释,所以对0根底的人员来说,可能须要额定的工夫去补充一下常识。

2 具体设计

2.1 需要剖析

对 实现需求 进行详细分析,次要有下:

性能阐明
应用Unittest框架开源自动化测试框架,间接应用
批量或指定用例运行Unittest框架可反对此性能
log日志应用Python的logging库即可
生成HTML测试报告应用HtmlTestRunner.py模块可实现此性能
用例设计和后果拆散应用配置文件如excel、json等组织用例数据
反对Json、conf、excel等配置文件读取这里先应用excel进行页面元素的驱动
用户登录封装间接把登录性能模块化,应用Unittest框架中的setup,teardown即可
定制测试报告模板应用HTMLTestRuner.py模块
报告多语言应用HTMLTestRuner.py模块
截图性能应用Selenium的save_screenshot办法

2.2 技术栈

技术版本及阐明
PythonV3.x(本文为3.7)===编程语言撑持
SeleniumV3.141.0 ===UI元素、控件的辨认、定位,以及浏览器管制等
HtmlTestRunnerPython3版本===生成Html测试报告
LoggingPython自带===生成log日志
XlrdV1.2.0===excel读取办法
UnittestPython自带===自动化测试框架
SmtplibPython自带===邮件服务
emailPython自带===邮件服务
osPython自带===零碎模块
PyCharmCommunity 2020.2汉化版
操作系统Windows10旗舰版64位
其它后续补充

3 框架设计

3.1 框架阐明

3.2 框架执行流程

4 预期后果

4.1 测试过程log日志

4.2 测试报告html格局

4.3 测试报告邮件格局

5 特地阐明

代码根本实现,如果有好的倡议,可交换学习心得。

6 第一个WebUI自动化测试程序


在开始自动化框架搭建之前,咱们先写一个简略的自动化测试脚本,来领会一下什么是web UI自动化测试,以及元素的基本操作,为后续的框架搭建鉴定根底。


6.1 Selenium根本实践

6.1.1 Selenium装置

  • 间接关上cmd窗口,输出以下命令在线装置:
pip3 install selenium

  • 装置完后,在cmd窗口中输出以下命令,能够看到selenium曾经装置了
pip list

6.1.2 WebDriverAPI

selenium提供了很多的WebDriverAPI,能够来进行:

  • 元素的辨认、定位
  • 元素的单击、双击
  • 滚动条的拖动
  • 浏览器管制如窗口大小、后退后退、刷新、表单切换、多窗口切换、文件双传下载、cookie操作、验证码等等
  • 详情请参考以下:
    Selenium WebDriver API 学习笔记(一):元素定位
    Selenium WebDriver API 学习笔记(二):浏览器管制
    Selenium WebDriver API 学习笔记(三):浏览器管制

6.2 浏览器驱动装置

  • 要想应用selenium来操作浏览器上的元素,必须装置浏览器驱动;
  • 这个要依据具体的浏览器版本来定义;
  • 本文应用的是Chrome浏览器,版本为88.0.4324.182(正式版本) (32 位);

6.2.1 Chromedriver下载

  • 下载地址:Chrome浏览器各版本对应的驱动

6.2.2 Chromedriver装置

  • 下载下来后是一个chromedriver.exe,如果是w7零碎须要把chromedriver.exe放在chrome浏览器的装置目录,而后在零碎环境变量中退出chrome浏览器的装置目录即可;如果是w10零碎,须要chromedriver.exe放在Python的装置目录即可,如本文是:

6.3 代码设计思路

6.3.1 pycharm新建脚本

  • 关上之前创立的我的项目【Automated-UITest-demo】,在我的项目上右键,新建python文件即可,这里新建一个名为test_baidu的python文件


  • 创立完后,如下多了一个test_baidu的py文件

6.3.2 自动化需要

这里咱们做以下UI自动化测试:
1、主动关上chrome浏览器
2、输出百度网址
3、关上百度首页,输出helloworld
4、最大化浏览器窗口
5、搜寻helloworld.并回车
6、浏览器窗口大小放大为640*480
7、先进行浏览器后退,再次输出csdn进行搜寻
8、清空输出的内容
9、判断是否进入csdn官网

6.3.3 需要剖析

需要剖析
主动关上chrome浏览器须要用到webdriver.Chrome()
输出百度网址用到driver.get()办法
关上百度首页,输出helloworld用到send_keys()办法
最大化浏览器窗口应用maximize_window()办法
搜寻helloworld.并回车用到send_keys()办法
浏览器窗口大小放大为640*480用到 set_window_size()办法
浏览器后退back()办法
清空输出的内容clear()办法
判断driver.current_url办法来判断以后的网址
  • 以上办法具体应用,参考【1.2 WebDriverAPI】

6.3.4 元素定位

  • 以上需要曾经搞清楚了,那么接下来要进行元素定位,这里大略能够对需要再拆解下,须要哪些元素?
元素阐明定位形式
百度输入框用来输出helooworldfind_element_by_id
搜寻csdn后点击csdn官网用来模仿点击进入到csdn官网find_element_by_xpath
  • 那如何定位元素,晓得应用哪种定位形式?

A、咱们关上百度首页,而后按【F12】关上浏览器的调试模式

B、点击调试模式窗口左上角的小三角

C、鼠标挪动到百度搜寻输入框

D、点击一下即可,而后看到搜寻输入框的元素属性,即要应用的元素定位办法

6.4 代码实现

6.4.1 包/模块的引入

  • 关上方才新建的test_baidu.py文件
  • 而后输出以下内容:
from selenium import webdriver  # 引入selenium模块的webdriverfrom selenium.webdriver.common.keys import Keys  # 键盘输入,所以要用到Keys  import time  # 元素等待时间,所以引入time模块

6.4.2 关上百度

driver = webdriver.Chrome()  # 关上Chrome浏览器driver.get("http://www.baidu.com")  # 输出百度网址print("============验证浏览器的根本管制==========")

6.4.3 定位搜寻框输出helloworld,窗口最大化

def search():    print("1、搜寻helloworld.并回车......")    time.sleep(2)    driver.find_element_by_id("kw").send_keys("helloworld")  # 输出“helloworld”    time.sleep(2)    driver.find_element_by_id("kw").send_keys(Keys.ENTER)  # 回车进行搜寻    time.sleep(2)    driver.maximize_window()  # 最大化以后窗口

6.4.4 窗口放大为640*480

def windows_size():    print("2、浏览器窗口大小放大为640*480......")    time.sleep(2)    driver.set_window_size(640, 480)  # 管制浏览器显示尺寸为640*480    time.sleep(0.5)    driver.maximize_window()  # 最大化以后窗口    time.sleep(2)

6.4.5 窗口刷新

ef back_refresh():    print("3、先进行浏览器后退,再次输出csdn进行搜寻")    driver.back()    driver.find_element_by_id("kw").send_keys("csdn")  # 输出csdn    time.sleep(1)    driver.refresh() # 刷新

6.4.6 清空输出内容

def serach_clear():    print("4、清空输出的内容......")    driver.find_element_by_id("kw").send_keys("csdn")  # 输出csdn    time.sleep(2)    driver.find_element_by_id("kw").clear()    time.sleep(0.5)

6.4.7 进入csdn官网并判断

def csdn():    print("5、进入csdn官网")    driver.find_element_by_id("kw").send_keys("csdn")  # 输出csdn    time.sleep(2)    driver.find_element_by_id("kw").send_keys(Keys.ENTER)  # 回车进行搜寻    time.sleep(2)    driver.find_element_by_xpath("//*[@id='1']/h3/a[1]").click()    time.sleep(2)    windows = driver.window_handles    driver.switch_to.window(windows[-1])    now_url = driver.current_url    m_get_url = "https://www.csdn.net/"    if now_url == m_get_url:        print("通过判断,曾经进入csdn官网!!")    else:        print("未进入到csdn官网,请查看代码!")

6.4.8 调用办法

search()windows_size()back_refresh()serach_clear()csdn()driver.quit()  # 敞开浏览器

6.5 残缺源码

# 作者:Administrator# 日期:2021/2/24 15:15# 文件名称:test_baidu.py# Function:关上百度网主页,在搜寻栏输出“helloworld”from selenium import webdriverfrom selenium.webdriver.common.keys import Keysimport timedriver = webdriver.Chrome()  # 关上Chrome浏览器driver.get("http://www.baidu.com")  # 输出百度网址print("============验证浏览器的根本管制==========")def search():    print("1、搜寻helloworld.并回车......")    time.sleep(2)    driver.find_element_by_id("kw").send_keys("helloworld")  # 输出“helloworld”    time.sleep(2)    driver.find_element_by_id("kw").send_keys(Keys.ENTER)  # 回车进行搜寻    time.sleep(2)    driver.maximize_window()  # 最大化以后窗口def windows_size():    print("2、浏览器窗口大小放大为640*480......")    time.sleep(2)    driver.set_window_size(640, 480)  # 管制浏览器显示尺寸为640*480    time.sleep(0.5)    driver.maximize_window()  # 最大化以后窗口    time.sleep(2)def back_refresh():    print("3、先进行浏览器后退,再次输出csdn进行搜寻")    driver.back()    driver.find_element_by_id("kw").send_keys("csdn")  # 输出csdn    time.sleep(1)    driver.refresh() # 刷新def serach_clear():    print("4、清空输出的内容......")    driver.find_element_by_id("kw").send_keys("csdn")  # 输出csdn    time.sleep(2)    driver.find_element_by_id("kw").clear()    time.sleep(0.5)def csdn():    print("5、进入csdn官网")    driver.find_element_by_id("kw").send_keys("csdn")  # 输出csdn    time.sleep(2)    driver.find_element_by_id("kw").send_keys(Keys.ENTER)  # 回车进行搜寻    time.sleep(2)    driver.find_element_by_xpath("//*[@id='1']/h3/a[1]").click()    time.sleep(2)    windows = driver.window_handles    driver.switch_to.window(windows[-1])    now_url = driver.current_url    m_get_url = "https://www.csdn.net/"    if now_url == m_get_url:        print("通过判断,曾经进入csdn官网!!")    else:        print("未进入到csdn官网,请查看代码!")search()windows_size()back_refresh()serach_clear()csdn()driver.quit()  # 敞开浏览器