TestCase——> Test Fixure测试固件

|

TestSuite测试套件——>TestRunner测试运行器

|

TestReport

测试断言

verbosity=2

0代表得到执行的测试总数和全局结果

1代表得到成功的显示,失败的显示f,错误的显示e,默认的是1

2可以得到详细的信息

1.unittest各个组件

2.unittest测试固件

a.setUp&tearDown

b.setUpClass&tearDownClass

#!/usr/bin/env python
#coding:utf-9 import unittest
import selenium import webdriver class F2(unittest.TestCase):
@classmethod
def selfUpClass(cls):
cls.driver=webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicityly_wait(30)
cls.driver.get("http://www.baidu.com")
@classmethod
def tearDown(cls):
cls.driver.quit()
def test_baidu_new(self):
self.driver.find_element_by_link_text('新闻').click()
def test_baidu_map(self):
self.driver.find_element_by_link_text('地图').click()
if __name__=="__main__":
unittest.main(verbosity=2)
类方法:会出现找不到元素的问题
改写成:
def test_baidu_new(self):
self.driver.find_element_by_link_text('新闻').click()
self.driver.back() import  unittest
from selenium import  webdriver class F3(unittest.TestCase):
    def setUp(self):
        self.driver=webdriver.Chrome()
        self.driver.maximize_window()
        self.driver.implicitly_wait(30)
        self.driver.get('http://www.baidu.com')     def tearDown(self):
        self.driver.quit()     def test_baidu_news(self):
        self.driver.find_element_by_link_text('新闻').click()     def test_baidu_map(self):
        self.driver.find_element_by_partial_link_text('图').click() if __name__ == '__main__':
    unittest.main(verbosity=2)

c.程序执行的顺序

d.测试用例的编写方法

写注释,好判断是哪个用例有错误

3.测试执行

4.构建测试套件,就是测试集

a用例按顺序执行(addTest)

#!/usr/bin/env python
#coding:utf-9 import unittest
import selenium import webdriver class BaiduTest(unittest.TestCase):
@classmethod
def selfUpClass(cls):
cls.driver=webdriver.Chrome()
cls.driver.maximize_window()
cls.driver.implicityly_wait(30)
cls.driver.get("http://www.baidu.com")
@classmethod
def tearDown(cls):
cls.driver.quit()
def test_baidu_new(self):
self.driver.find_element_by_link_text('新闻').click()
self.driver.back()
def test_baidu_map(self):
self.driver.find_element_by_link_text('地图').click()
self.driver.back()
if __name__=="__main__":
suite=unittest.TestSuite()初始化
suite.addTest(BaiduTest('test_baidu_new'))
suite.addTest(BaiduTest('test_baidu_man'))
unittest.TextTestRunner(verbosity=2).run(suite)
执行顺序还是会按照ASCII字母顺序执行,
解决方法就是把用例名用数字编号显示,但是addTest会产生很多相同代码,解决办法就是按类执行
if __name__=="__main__":
suite=unittest.TestSuite()初始化
suite.addTest(BaiduTest)
unittest.TextTestRunner(verbosity=2).run(suite)

b.测试用例执行顺序的详解

c.按测试类执行makeSuite,是个函数

#!/usr/bin/env python
# coding:utf-8 import unittest
from selenium import webdriver class F7(unittest.TestCase):
def setUp(self):
pass
def tearDown(self):
pass
def test_001(self):
pass
def test_002(self):
pass
if __name__=="__main__":
suite=unittest.TestSuite(unittest.makeSuite(F7))
unittest.TextTestRunner(verbosity=2).run(suite)

d.加载测试类

e按测试模块来执行

if __name__=="__main__":
suite=unittest.TestLoader().loadTestsFromModult('f8.py')
unittest.TextTestRunner(verbosity=2).run(suite)

f优化测试套件

#!/usr/bin/env python
# coding:utf-8 import unittest
from selenium import webdriver class BaiduLink(unittest.TestCase):
def setUp(self):
self.driver=webdriver.Chrome()
self.driver.maximize_window()
self.driver.implicitly_wait(30)
self.driver.get('http://www.baidu.com')
def tearDown(self):
self.driver.quit()
pass
def test_001(self):
self.driver.find_element_by_link_text('新闻').click()
def test_002(self):
self.driver.find_element_by_link_text('地图').click()
@staticmethod
def suite():
suite = unittest.TestSuite(unittest.makeSuite(BaiduLink))
return suite
if __name__ =="__main__":
unittest.TextTestRunner(verbosity=2).run(BaiduLink.suite())

5.分离测试固件(模块化的应用)

init.py

#! /usr/bin/env python
codring:utf-8 import unittest
from selenium import webdriver
class Init(unittest.TestCase):
def setUp(self):
self.driver=webdriver.Chrome()
self.driver.maximize_window()
self.driver.implicity_wait(30)
self.driver.get('http://www.baidu.com')
def tearDown(self):
self.driver.quit()
#!/usr/bin/env python
# coding:utf-8
import unittest from Day10.Init import *
class BaiduSo(Init): self test_baidu_news(self):
self.driver.find_element_by_id('kw').send_keys('webdriver') if __name__=="__main__":
unittest.main(verbosity=2) 取消测试用例
@unittest.skip('该功能已经取消,忽略该测试用例的执行')
@unittest.expectedFailure 期望测试用例执行失败
 

6.测试断言

assertEqual(a,b)  内容一致,类型一致

#coding:utf-8
import unittest
from Day10.init import * class BaiduLink(Init):
def test_baidu_news(self):
print(self.driver.title,type(self.driver.title))
self.assertEqual(self.driver.title,u'百度一下,你就知道') if __name__=="__main__":
unittest.main(verbosity=2)

assertTrue(x)

def test_baidu_so(self):
so = self.driver.find_element_by_id('kw')
print so.is_enable()
self.assertTrue(so.is_enabled())

assertIn(a,b)

def test_baidu_title(self):
self.assertIn('百度',self.driver.title)

测试断言注意事项

   不正确的使用if

  不正确的使用异常

7.批量执行测试用例(discover)

#!/usr/bin/env python
# coding:utf-8 import unittest
import os def allTests():
suite=unittest.TestLoader.discover(
start_dir = os.path.dirname(__file__),
pattern = 'test_*.py',
top_level_dir=None)
return suite def run():
unittest.TextTestRunner(verbosity=2).run(allTests()) if __name__=="__main__":
run()

a.获取所有测试用例

b.discover方法的解读

8.生成测试报告

a.python2测试报告的生成

import sys
reload(sys)
sys.setdefaultencoding('utf-8')

b.python3测试报告的生成

!/usr/bin/env python
# coding:utf-8 import unittest
import os
import HTMLTestRunner def allTests():
suite=unittest.TestLoader.discover(
start_dir = os.path.dirname(__file__),
pattern = 'test_*.py',
top_level_dir=None)
return suite def run():
fp=os.path.join(os.path.dirname(__file__),'report','testReport.html')
HTMLTestRunner.HTMLRunner(
stream = open(fp,'wb'),
title ='自动化测试报告',
description='自动化测试详细信息').run(allTests()) if __name__=="__main__":
run()

c.测试报告的注意事项

d.新增当前时间

9.unittest的缺陷

10.Coverage的应用

Python-Unittest的更多相关文章

  1. 从python run 和python unittest两种eclipse运行方式深入理解if __name__ == "__main__"

    在写一个简单的python测试程序的时候,发现eclipse中Run as "Python run 和 Python unittest”结果不一样?为什么会不一样? 先贴一下代码段: # - ...

  2. 自动化测试神器 之 python unittest 断言

    自动化测试的最后一步需要判断结果是否正确,而正确设置断言可以帮助判断测试用例的执行结果,从而提高自动化测试的效率,python unittest  提供了一个比较完整的断言方法.unittest框架测 ...

  3. 第二种方式,修改python unittest的执行顺序,使用猴子补丁

    1.按照测试用例的上下顺序,而不是按方法的名称的字母顺序来执行测试用例. 之前的文章链接 python修改python unittest的运行顺序 之前写的,不是猴子补丁,而是要把Test用例的类名传 ...

  4. Pycharm上python unittest不执行"if __name__ == '__main__' "问题or选择非unittest run

    转:http://www.cnblogs.com/csjd/p/6366535.html python unittest不执行"if __name__ == '__main__' " ...

  5. 简单实现接口自动化测试(基于python+unittest)

    简单实现接口自动化测试(基于python+unittest) 简介 本文通过从Postman获取基本的接口测试Code简单的接口测试入手,一步步调整优化接口调用,以及增加基本的结果判断,讲解Pytho ...

  6. python+unittest 搭建简易的接口测试框架

    主要介绍如何使用python+unittest快速搭建一个接口测试的框架 1.安装python  unittest 2.新建一个python项目ApiTest 在setUp和setDown里设置一些需 ...

  7. Python unittest基本框架组成(1)

    Python的标准库——unittest(可以实现自动化测试框架的搭建) python unittest四大组成“元件”: test fixture(测试脚手架)——测试代码的运行环境,指测试准备前和 ...

  8. Python+Unittest+Requests+PyMysql+HTMLReport 接口自动化框架

    整体框架使用的是:Python+Unittest+Requests+PyMysql+HTMLReport  多线程并发模式 主要依赖模块 Unittest.Requests.PyMysql.HTMLR ...

  9. 接口自动化-python unittest+requests+HTMLrunner

    从2015年毕业入行软件测试,快满4年了,之前技术分享都在百度贴吧上面,现在正式开始在博客中记录工作技术,努力成长,加油 接口测试的步骤1.组装好该接口需要的参数数据2.使用get或post附带参数数 ...

  10. Python+Unittest+Requests+PyMysql+HTMLReport 多线程并发接口化框架

    整体框架使用的是:Python+Unittest+Requests+PyMysql+HTMLReport 多线程并发模式 主要依赖模块 Unittest.Requests.PyMysql.HTMLRe ...

随机推荐

  1. MySQL出现too many connections(1040)错误解决方法

    https://www.cnblogs.com/2881064178dinfeng/p/6938112.html 其实MySQL默认的最大连接数为100,可能在大访问量的时候造成了连接不上数据库.解决 ...

  2. javascript常见问题总结

    1.const obj = {a:6}; obj.b=8; obj.a=9;//obj为{a:9,b:8};const定义对象的时候是可以改变内容的. const b = "hello&qu ...

  3. gcc的调试调研——gdb

    首先来介绍一下gcc的选项: 其他选项都为常用编译选项,在这里介绍一下优化功能: 优化编译时使用选项: -O:可以告诉gcc同时减小代码的长度和执行时间,其效果等价于-O1,在这一级别上能够进行的优化 ...

  4. Java面向对象和高级特性 项目实战(一)

    一.项目简介 项目名:嗖嗖移动业务大厅 技能点: 二.技能点 三.系统概述 四.整体开发思路 五.实体类和接口开发 六. 创建工具类 七.使用集合存储数据 八.开发计划 九.代码实现 1.项目目录 2 ...

  5. 2018-2019-2 20175202实验一《Java开发环境的熟悉》实验报告

    2018-2019-2 20175202实验一<Java开发环境的熟悉>实验报告 一.实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用IDEA 编辑.编译.运行.调试Jav ...

  6. python selenium-webdriver 下拉菜单处理 (九)

    测试过程中经常遇到下来菜单,比如说分页,每页显示的条数,以及语言的切换,很多时候经常是以下来菜单的形式展现,下面我们看一下selenium如何处理下来菜单. 首先selenium 很人性化的给提供了一 ...

  7. py-day3-6 python map函数

    map函数 :处理序列中的每个元素,得到的结果是一个列表,该列表元素个数及位置与原来一样 ## 求列表里元素的平方 (原始方法) num_1=[1,2,13,5,8,9] res =[] for i ...

  8. IntellijIDEA常用快捷键总结

    转载自:http://blog.csdn.net/qq_17586821/article/details/52554731 下面的这些常用快捷键需要在实际操作中不断地体会才能真正感受到它们的方便之处. ...

  9. Oauth2手册 第一章

    来源:https://github.com/jeansfish/RFC6749.zh-cn/blob/master/SUMMARY.md 1. 简介在传统的客户端-服务器身份验证模式中,客户端请求服务 ...

  10. Windos下pip配置豆瓣源

    C:\Users\liche\pip 下创建pip.ini文件 pip.ini [global] index-url = http://pypi.douban.com/simple [install] ...