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. 基于Linux-3.9.4的mykernel实验环境的极简内核分析

    382 + 原创作品转载请注明出处 + https://github.com/mengning/linuxkernel/ 一.实验环境 win10 -> VMware -> Ubuntu1 ...

  2. java基础(三):反射、反序列化破解单列模式和解决方式

    单例模式指的是一个类只有一个对象,通过一些措施达到达到这个目的.但是反射和反序列化可以获得多个不同的对象. 先简单的认识一下单例模式 一:单例模式 通过私有构造器,声明一个该类的静态对象成员,提供一个 ...

  3. return,break,continue三者区别

    详解:http://www.cnblogs.com/yangdabao/p/6172210.html return:直接结束这个方法,后面所有代码不再执行,不管循坏外,还是循环内,全部停止,直接返回 ...

  4. 《Self-Attention Generative Adversarial Networks》里的注意力计算

    前天看了 criss-cross 里的注意力模型  仔细理解了  在: https://www.cnblogs.com/yjphhw/p/10750797.html 今天又看了一个注意力模型 < ...

  5. 思科模拟器-DHCP配置

    一.如图做好以下拓扑图(下图我取消显示端口号) 二.配置最下面的四台上网终端为自动获取ip 三.配置中间的二层交换机:添加vlan,同时所有端口设为access类型并将其加入vlan中,以下以swit ...

  6. Hbase数据库

        1.简介 HBase从诞生至今将近10年,在apache基金会的孵化下,已经变成一个非常成熟的项目,也有许多不同的公司支持着许多不同的分支版本,如cloudra等等. HBase不同于一般的关 ...

  7. Fiddler2如何对Android应用进行抓包

    Fiddler2抓包工具的下载和使用  2018-04-22 18:06:37     0     0     0 Fiddler是一款非常流行并且实用的http抓包工具,它的原理是在本机开启了一个h ...

  8. xml和java对象互转:JAXB注解的使用详解

    先看工具类: import org.slf4j.Logger; import javax.xml.bind.JAXBContext; import javax.xml.bind.Marshaller; ...

  9. vue实现原理

    1.数据监控(data):监听data属性: new Vue之后内部扫描data属性值,用 Object.defineProperty(obj,name,{ set:value=>{ obj[_ ...

  10. ObjectARX2012+ObjectARX Wizards2012+AutoCAD2012+MVS2008 环境配置

    1  版本选择 ObjectARX本身采用的MVS编译平台,因此选择ObjectARX的编译平台作为二次开发的平台,兼容性最好,当然别的平台也不是一定不可以.目前已知的对应关系如下: R15   -- ...