selenium + python自动化测试unittest框架学习(二)
1.unittest单元测试框架文件结构
unittest是python单元测试框架之一,unittest测试框架的主要文件结构:
File
>report
>all_case.py
>test_case
>__init__.py
>test_case1.....
>public
>__init__.py
>login.py
>loginout.py
test_case文件夹主要存放测试用例,且测试用例命名以test_开头
public文件夹是test_case文件夹的子文件夹,主要存放公共模块,例如登录退出模块
report文件夹主要存放在测试用例执行完成后生成的测试报告
all_case脚本文件是主要的执行脚本,该脚本集合所有测试用例,执行所有的测试用例
2.unittest框架的最简单结构
在selenium + python自动化测试unittest框架学习(一)selenium原理及应用这篇中说道可以将录制的浏览器行为导出成指定的编程语言,如果我们先是通过Selenium ide录制后导出的python脚本,那么可以发现每一个脚本的都会有这样一个简单的结构,先忽略那些判断元素是否存在的函数。其基本的结构如下所示:
setUp()
tearDown()
test_case1()
unittest.main()
setUp:初始化函数,每一个测试用例执行之前都会执行一遍
tearDown:测试用例执行完成后的浏览器退出等清理操作
test_case1():编写的测试用例脚本
unittest.main():自动执行方法名为test_开头的方法
3.unittest测试框架优化结构2
单单一个脚本不可能包含所有的测试用例,所以不同的测试用例可以写成不同的测试用例脚本放置在test_case文件夹中,那么执行测试用例的时候我们需要一个测试套件TestSuite来加载所有的测试用例脚本,添加测试用例的方法addTest(),并且使用TextTestRunner运行测试脚本。
- 先构造测试集
- 实例化测试套件
- suite=unittest.TestSuite()
- 将测试用例加载到测试套件中。
- suite.addTest(Test('test_case2'))
- suite.addTest(Test('test_case1'))
- 实例化测试套件
- 执行测试用例
- 实例化TextTestRunner类
- runner=unittest.TextTestRunner()
- 使用run()方法运行测试套件(即运行测试套件中的所有用例)
- runner.run(suite)
- 实例化TextTestRunner类
该结构的缺点是每一个测试用例的增加都要添加一条addTest()方法,这就增加自动化脚本上的繁琐,所以我们可以想办法自动加载符合条件的测试用例
4.unittest测试框架优化结构3
该结构简化了一些步骤,即不用先创建测试套件,然后通过添加测试用例的方式,将测试用例逐条加载,TestLoader下的discover方法可以递归查询其指定路径下的子目录下符合条件的测试用例加载。
test_dir = './'
discover = unittest.defaultTestLoader.discover(test_dir, pattern='test_*.py')
执行测试用例
实例化TextTestRunner类
runner=unittest.TextTestRunner()
使用run()方法运行测试套件(即运行测试套件中的所有用例)
runner.run(discover)
5.unittest执行文件all_case.py代码结构如下:
# coding=utf-8
import unittest
import HTMLTestRunner
import time
from test_case.public import login def createsuit():
#创建测试用例集
testunit = unittest.TestSuite()
#判断是否为测试用例,自动加载测试用例到测试套件中
cslist = "D:\\fcj\\study\\seleniumtest\\test_case"
#discover方法定义
discover = unittest.defaultTestLoader.discover(
#测试用例放置的文件夹名
cslist,
pattern = 'test_*.py',
top_level_dir = None
) #discover方法筛选出来的用例,循环添加到测试套件中
for test_suite in discover:
testunit.addTests(test_suite)
print(testunit)
return testunit
alltestnames = createsuit() if __name__ == "__main__":
now = time.strftime('%Y-%m-%d-%H_%M_%S',time.localtime(time.time()))
#定义报告存放路径
filename = 'D:\\fcj\\study\\seleniumtest\\report\\'+now+'result.html'
fp = open(filename,'wb')
#定义测试报告
runner = HTMLTestRunner.HTMLTestRunner(
stream = fp,
title = u'A项目后台测试报告',
description = u'用例执行情况:'
)
#执行测试
runner.run(alltestnames)
fp.close()
selenium + python自动化测试unittest框架学习(二)的更多相关文章
- selenium + python自动化测试unittest框架学习(五)webdriver的二次封装
因为webdriver的api方法很长,再加上大多数的定位方式是以xpath方式定位,更加让代码看起来超级长,为了使整体的代码看起来整洁,对webdriver进行封装,学习资料来源于虫师的<se ...
- selenium + python自动化测试unittest框架学习(一)selenium原理及应用
unittest框架的学习得益于虫师的<selenium+python自动化实践>这一书,该书讲得很详细,大家可以去看下,我也只学到一点点用于工作中,闲暇时记录下自己所学才能更加印象深刻. ...
- selenium + python自动化测试unittest框架学习(三)webdriver元素操作(二)
上一篇是元素的定位,那么定位元素的目的就是对元素进行操作,例如写入文本,点击按钮,拖动等等的操作 (1)简单元素操作 简单元素操作 find_element_by_id("kw") ...
- selenium + python自动化测试unittest框架学习(三)webdriver元素定位(一)
1.Webdriver原理 webdirver是一款web自动化操作工具,为浏览器提供统一的webdriver接口,由client也就是我们的测试脚本提交请求,remote server浏览器进行响应 ...
- selenium + python自动化测试unittest框架学习(七)随机生成姓名
在自动化测试过程中经常要测试到添加用户的操作,每次都要输入中文,原本是找了十几个中文写成了列表,然后从列表中随机取出填入用户名文本框中,随着测试的增加,发现同名的人搜索出来一大堆,最后在网上找了个随机 ...
- selenium + python自动化测试unittest框架学习(四)python导入模块及包知识点
在写脚本的时候,发现导入某些模块,经常报错提示导入模块失败,这里来恶补下python导入模块的知识点. 1.模块导入时文件查找顺序 在脚本中,import xxx模块时的具体步骤: (1)新建一个mo ...
- selenium + python自动化测试unittest框架学习(六)分页
接触的项目分页的形式是以下形式: 想要获取总页数后,遍历执行翻页的功能,但由于分页是以javascript方法实现的,每次点击确定按钮后,页面就回刷新,webelement元素过期无法遍历下一个进行翻 ...
- selenium + python自动化测试unittest框架学习(三)webdriver对页面其他控件操作(三)
1.对话框,下拉框 (1)对话框的有两种,一种是iframe格式的,需要switch_to_iframe()进行定位,现在大部分的对话框是div格式的,这种格式的可以通过层级定位来定位元素,先定位对话 ...
- Selenium终极自动化测试环境搭建(二)Selenium+Eclipse+Python
Selenium终极自动化测试环境搭建(二)Selenium+Eclipse+Python 前面举例了Selenium+Eclipse+Junit+TestNG自动化测试环境的搭建,在前一篇的基础上, ...
随机推荐
- Java学习网址
JAVA学习记录均参考自爱慕课网址: 爱慕课:http://www.imooc.com/course/list?c=java
- [C#]浅谈协变与逆变
看过几篇说协变与逆变的博客,虽然都是正确无误的,但是感觉都没有说得清晰明了,没有切中要害.那么我也试着从我的理解角度来谈一谈协变与逆变吧. 什么是协变与逆变 MSDN的解释:https://msdn. ...
- 七、spark核心数据集RDD
简介 spark RDD操作具体参考官网:http://spark.apache.org/docs/latest/rdd-programming-guide.html#overview RDD全称叫做 ...
- 撩课-Java每天10道面试题第6天
51.HashMap的实现原理 HashMap的主干是一个Entry数组. Entry是HashMap的基本组成单元, 每一个Entry包含一个key-value键值对. HashMap基于hashi ...
- webpack打包踩坑之TypeError: Cannot read property 'bindings' of null
file loader介绍:https://www.webpackjs.com/loaders/file-loader/ babel loader介绍:https://webpack.js.org/l ...
- MySQL:入门
一.前言 MySQL :是用于管理数据的软件 MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性. 分为服务端和客户 ...
- js中作用域链和作用域
作用域 在JavaScript中,我们可以将作用域定义为一套规则,这套规则用来管理引擎如何在当前作用域以及嵌套的子作用域中根据标识符名称(变量名或者函数名)进行变量查找. 经过研究<高级程序设计 ...
- Java中int与Integer的区别
转自https://www.cnblogs.com/guodongdidi/p/6953217.html import java.lang.Integer; public class intDemo{ ...
- spring 与springmvc容器的关系
spring容器是springmvc的父容器,而父容器是不能访问子容器中的东西,但子容器可以访问父容器的东西
- SSM 框架集-01-详细介绍-入门问题篇
SSM 框架集-01-详细介绍-入门问题篇 刚开始了解 SSM,首先先解决几个基础问题 1.什么是 SSM 框架集? SSM(Spring+SpringMVC+MyBatis)框架集由 Spring. ...