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自动化测试环境的搭建,在前一篇的基础上, ...
随机推荐
- code.google.com certificate error: certificate is for www.google.com
有时候我们会碰到下面错误:code.google.com certificate error: certificate is for www.google.com,类似如下: D:\>go ge ...
- Spring入门(一)— IOC、DI
一.Spring介绍 Spring 是一个开源框架,是为了解决企业应用程序开发复杂性而创建的.框架的主要优势之一就是其分层架构,分层架构允许您选择使用哪一个组件,同时为 J2EE 应用程序开发提供集成 ...
- Hibernate入门(四)—— 查询
一.Hibernate查询 1.Hibernate检索(查询)方式的分类 OID检索 :根据主键查询,get/load 对象导航检索 :通过一个对象获得其关联对象.[重点] Category cate ...
- Lucas定理及扩展
Lucas定理 不会证明... 若\(p\)为质数 则\(C(n, m)\equiv C(n/p, m/p)*C(n\%p, m\%p)(mod\ p)\) 扩展 求 \(C(n,m)\) 模 \(M ...
- 使用iview时,页面没了滚动条
场景:页面中有一个确认按钮,保存后弹框预览在点保存按钮,实现数据提交.提交后回到数据列表页,用this.$router.push('list'),返回后页面无法滚动了. 原因:排查后发现弹框时在bod ...
- MathQuill.js
MathQuill.js通过html.css.javascript实现数学公式 <p>Type math here: <span id="math-field"& ...
- 单选按钮(RadioButton)
一:RadioButton的相关属性: 1.Activity //单选按钮 public class RadioButtonActivity extends Activity { private Co ...
- sql处理百万级以上的数据提高查询速度的方法
原文:http://blog.csdn.net/zhengyiluan/article/details/51671599 处理百万级以上的数据提高查询速度的方法: 1.应尽量避免在 where 子句中 ...
- Python爬虫教程-06-爬虫实现百度翻译(requests)
使用python爬虫实现百度翻译(requests) python爬虫 上一篇介绍了怎么使用浏览器的[开发者工具]获取请求的[地址.状态.参数]以及使用python爬虫实现百度翻译功能[urllib] ...
- Android获取蓝牙地址
最近做一个项目,发现Android6.0以上的版本获取的蓝牙地址始终为02:00:00:00, Google一下发现Android早就封掉了相关接口,于是想到反射的方式去获取Mac地址,在此记录一下 ...