PyTest自动化测试 学习基础知识之PyTest生成html测试报告;allure开源测试报告框架

目录

一、pytest简介

1.1运行成功则在命令行显示 类名+.

1.1.1CaculateAdd.py类(定义了add()和jian() 两个方法)

1.1.2TestPytestHtmlDemo.py类(pytest运行demo:注意是Test开头)

1.1.3运行几个成功类名后面就几个.

1.1.4运行错误的展示F

1.1.5运行几个错误 类名后就展示几个F

1.2Pytest生成自带的html测试报告

1.2.1运行代码如下:

1.2.2打开123.html

1.3 pytest -x的使用等

-x出现一条测试用例失败就退出测试

-v: 丰富信息模式, 输出更详细的用例执行信息

-s:显示print内容

-q: 简化结果信息,不会显示每个用例的文件名

二、allure开源测试报告

2.1安装allure

2.1.1配置allure,环境变量path配置:新增allure的bin目录下的路径

三、pytest和alluredir的生成测试报告json

3.1运行前

​3.2运行后(多了allurePackage/response文件夹)

3.3Pytest和allure结合生成html格式的测试报告

3.4index.html页面Allure测试报告

​ ​
四、Allure常用的几个特性

4.1 @allure.feature使用

4.2@allure.story

4.4with allure.step("用户登录"): # 用于描述测试步骤,将会输出到报告中 allure.attach("GUOYING","用户名") # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等


一、pytest简介

**需要安装pytest和pytest-html(生成html测试报告) **

**pip install pytest 和 pip install pytest-html **

**命名规则 **

**Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨 **

unittest:Setup>> setupclass teardown teardownclass

Pytest的setup, setup_class和teardown, teardown_class函数(和unittest执行效果一样) 运行于测试方法的始末,

**setup,teardown :即:运行一次测试函数会运行一次setup和teardown **

setup_class,teardown_class:运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class

1.1运行成功则在命令行显示 类名+.

1.1.1CaculateAdd.py类(定义了add()和jian() 两个方法)

class CaculateAddClass:    
def add(self,a,b):        
c = a+b        
return c    

def jian(self,a,b):        
d = a-b        
return d

1.1.2TestPytestHtmlDemo.py类(pytest运行demo:注意是Test开头)

from PyTest.CaculateAdd import CaculateAddClass
import pytest  

class TestPyDemoHtmlClass:   
def test_1(self):        
a = CaculateAddClass()        
c = a.add(1, 2)        
assert c == 3     

#先运行test_1,这个test_2一会儿在放开注释    
# def test_2(self):   
#     a = CaculateAddClass()    
#     d = a.jian(3, 2)    
#     assert d == 1 

 #程序主入口不写不运行
if __name__ == '__main__':    
pytest.main(['TestPytestHtmlDemo.py'])#['类名']运行这个类

运行结果:(因为1+2=3,assert c==3,符合程序运行结果,正确)

. 点号,表示用例通过

F 表示失败 Failure

E 表示用例中存在异常 Error

image

1.1.3运行几个成功类名后面就几个.

from PyTest.CaculateAdd import CaculateAddClass
import pytest  
class TestPyDemoHtmlClass:    
def test_1(self):        
a = CaculateAddClass()        
c = a.add(1, 2)        
assert c == 3        

def test_2(self):        
a = CaculateAddClass()        
d = a.jian(3, 2)        
assert d == 1  

#程序主入口不写不运行
if __name__ == '__main__':    
pytest.main(['TestPytestHtmlDemo.py'])#['类名']运行这个类

image

1.1.4运行错误的展示F

from PyTest.CaculateAdd import CaculateAddClass
import pytest  

class TestPyDemoHtmlClass:    
def test_1(self):        
a = CaculateAddClass()        
c = a.add(1, 2)        
assert c == 4     

#先运行test_1,这个test_2一会儿在放开注释    
# def test_2(self):    
#     a = CaculateAddClass()    
#     d = a.jian(3, 2)   
#     assert d == 1  

#程序主入口不写不运行
if __name__ == '__main__':   
pytest.main(['TestPytestHtmlDemo.py'])#['类名']运行这个类

运行结果:

image

1.1.5运行几个错误 类名后就展示几个F

image
image

1.2Pytest生成自带的html测试报告

1.在Pycharm安装pytest自带的测试报告包:
pip install pytest-html

2.直接执行pytest.main() 【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】

pytest.main("模块.py") 【运行指定模块下,运行所有test开头的类和测试用例】

**3.python自带的插件 **

pytest.main(["--html=./report.html","test3.py"])

# 程序主入口不写不运行if __name__ == '__main__':    pytest.main(["--html=./report.html", "TestPytestHtmlDemo.py"])  # 第一个参数是html,第二个是['类名']

1.2.1运行代码如下:

from PyTest.CaculateAdd import CaculateAddClass
import pytest  

class TestPyDemoHtmlClass:    
def setup(self):        
print("========setup========start")     

def test_1(self):        
a = CaculateAddClass()        
c = a.add(1, 2)       
assert c == 3     

def test_2(self):        
a = CaculateAddClass()        
d = a.jian(3, 2)        
assert d == 1     
def teardown(self):        
print("========teardown========end")  

# 程序主入口不写不运行
if __name__ == '__main__':    
pytest.main(["--html=./report.html", "TestPytestHtmlDemo.py"])  # 第一个参数是html,第二个是['类名']    # pytest.main(['-x','TestPytestHtmlDemo.py'])#['类名']运行这个类

运行结果:

image

1.2.2打开123.html

image
image

1.3 pytest -x的使用等

pytest.main(['-x','--html=./report.html','t12est000.py'])

-x出现一条测试用例失败就退出测试

-v: 丰富信息模式, 输出更详细的用例执行信息

-s:显示print内容

-q: 简化结果信息,不会显示每个用例的文件名

二、allure开源测试报告

** Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。**

2.1安装allure

首先要在Pycharm安装:allure-pytest是Pytest的一个插件,通过它我们可以生成Allure所需要的用于生成测试报告的数据

allure:

pip install allure-pytest

2.1.1配置allure,环境变量path配置:新增allure的bin目录下的路径

三、pytest和alluredir的生成测试报告json

import pytest  

class TestAllureClass:     
def test1(self):        
print("我是第一个数据")     
def test2(self):        
print("我是第二个数据")     
def test3(self):        
print("我是第三个数据") 

if __name__ == '__main__':    
#第一个是allure文件夹;    
#第二个是数据(json/txt)返回到这个目录下response文件夹下;    
#第三个类名    

pytest.main(['--alluredir','allurePackage/response','TestAllure.py'])    
# pytest.main(['--html=./321.html','TestAllure.py'])

3.1运行前

image

3.2运行后(多了allurePackage/response文件夹)

image

3.3Pytest和allure结合生成html格式的测试报告

pytest.main(['--alluredir','allurePackage/response','TestAllure.py'])    
## 将测试报告转为html格式# --html=../report.html    

split = 'allure ' + 'generate ' + './allurePackage/response ' + '-o ' + './allurePackage/html ' + '--clean'    os.system(split)#system函数可以将字符串转化成命令在服务器上运行

运行前:

image

运行后:

image

3.4index.html页面Allure测试报告

image

image

四、Allure常用的几个特性

@allure.feature # 用于描述被测试产品需求

@allure.story # 用于描述feature的用户场景,即测试需求

with allure.step(): # 用于描述测试步骤,将会输出到报告中

**allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等 **

4.1 @allure.feature使用

import pytest,os,allure  
class TestAllureClass:     

@allure.feature("用户登录功能")    
def test1(self):        
print("我是第一个数据")     

@allure.feature("用户注册功能")    
def test2(self):        
print("我是第二个数据")     

@allure.feature("用户注册/登录功能")    
def test3(self):        
print("我是第三个数据") 

if __name__ == '__main__':   
# pytest.main(['--html=./321.html','TestAllure.py'])    
#生成测试报告json    #第一个是allure文件夹;    
#第二个是数据(json/txt)返回到这个目录下response文件夹下;   
#第三个类名    
pytest.main(['--alluredir','allurePackage/response','TestAllure.py'])    
## 将测试报告转为html格式# --html=../report.html    
split = 'allure ' + 'generate ' + './allurePackage/response ' + '-o ' + './allurePackage/html ' + '--clean'    os.system(split)#system函数可以将字符串转化成命令在服务器上运行

运行后:

image

4.2@allure.story

import pytest,os,allure  

class TestAllureClass:     
@allure.feature("用户登录功能")    
@allure.story("步骤1")    
def test1(self):        
print("我是第一个数据")     

@allure.feature("用户注册功能")    
@allure.story("步骤2")    
def test2(self):        
print("我是第二个数据")     

@allure.feature("用户注册/登录功能")   
@allure.story("步骤3")    
def test3(self):        
print("我是第三个数据") 

if __name__ == '__main__':    
# pytest.main(['--html=./321.html','TestAllure.py'])    
#生成测试报告json    
#第一个是allure文件夹;    
#第二个是数据(json/txt)返回到这个目录下response文件夹下;    
#第三个类名    
pytest.main(['--alluredir','allurePackage/response','TestAllure.py'])    
## 将测试报告转为html格式# --html=../report.html    
split = 'allure ' + 'generate ' + './allurePackage/response ' + '-o ' + './allurePackage/html ' + '--clean'    os.system(split)#system函数可以将字符串转化成命令在服务器上运行

运行结果:

image
image

4.4with allure.step("用户登录"): # 用于描述测试步骤,将会输出到报告中

 allure.attach("GUOYING","用户名")  # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
import pytest,os,allure  
class TestAllureClass:     
@allure.feature("用户登录功能")    
@allure.story("步骤1")    
def test1(self):        
with allure.step("用户登录"): 
# 用于描述测试步骤,将会输出到报告中            
allure.attach("GUOYING","用户名")  
# 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等        
with allure.step("商品查看"):            
allure.attach("玛莎拉蒂","MC20")        
print("我是第一个数据")     

@allure.feature("用户注册功能")    
@allure.story("步骤2")    def test2(self):        
print("我是第二个数据")     

@allure.feature("用户注册/登录功能")    
@allure.story("步骤3")    
def test3(self):        
print("我是第三个数据") 

if __name__ == '__main__':    
# pytest.main(['--html=./321.html','TestAllure.py'])    
#生成测试报告json    
#第一个是allure文件夹;    
#第二个是数据(json/txt)返回到这个目录下response文件夹下;    
#第三个类名    
pytest.main(['--alluredir','allurePackage/response','TestAllure.py'])    
## 将测试报告转为html格式# --html=../report.html   
split = 'allure ' + 'generate ' + './allurePackage/response ' + '-o ' + './allurePackage/html ' + '--clean'    os.system(split)#system函数可以将字符串转化成命令在服务器上运行

image

运行结果:

image
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349