参数化有三种,代码驱动,数据驱动,关键字驱动

代码驱动,测试数据写在代码中 如下:

import requests,json
import unittest
import BeautifulReport
fido_url = 'http://192.168.6.162:8080/uaf/reg/receive'
'''代码驱动,代码实现做参数化的例子'''
reg_receive_data1 = {
"context": {
"appID":"",
"transNo":"",
"userName":"mh",
"transType":"",
"authType":"",
"opType":"",
"devices":{"deviceName": "HUA WEI", "deviceType": "iPhone 7", "deviceID": ""}
}
}
reg_receive_data2 = {
"context": {
"appID":"",
"transNo":"",
"userName":"mh",
"transType":"",
"authType":"",
"opType":"",
"devices":{"deviceName": "HUA WEI", "deviceType": "iPhone 7", "deviceID": ""}
}
}
headers = {
"Connection": "keep-alive",
"Content-Type": "application/json",
"Content-Length": "",
"Host": "192.168.6.162:8080",
"User-Agent": "Apache-HttpClient/4.2.6 (java 1.5)"
}
def fido_reg(url,data,headers):
r = requests.post(url=url,data=json.dumps(data),headers=headers).json()
return r
print(fido_reg(fido_url,reg_receive_data1,headers))#正常的返回
class Reg_receive(unittest.TestCase):
def test(self):
'''请求正常'''
result = fido_reg(fido_url,reg_receive_data1,headers)
self.assertEqual(1200,result.get('statusCode'))
self.assertEqual('OK',result.get('description'))
def test_02(self):
'''appid为空'''
result = fido_reg(fido_url,reg_receive_data2,headers)
self.assertEqual(1401,result.get('statusCode'))
self.assertEqual('Parameter- appID is EMPTY',result.get('description')) bf = BeautifulReport.BeautifulReport(unittest.makeSuite(Reg_receive))
bf.report(filename='测试报告1',description='接口测试报告')

数据驱动,代码读取excel,或txt

import xlrd
import requests
import unittest
import BeautifulReport as bf
import time
import parameterized
import json
path = 'testcase_adapter.xlsx'#定义测试用例名字
testreport = time.strftime('%Y%m%d',time.localtime())#定义测试报告名字
class Op_excel:
def r_excel(self,path):
r_workbook = xlrd.open_workbook(path)
r_sheet = r_workbook.sheets()[0]
return r_sheet,r_workbook
#读excel def get_nrows(self,r_sheet):
nrows = r_sheet.nrows
return nrows e = Op_excel()#实例化一个操作excel的类的对象
newsheet = e.r_excel(path)[0]#对象调用类的操作读excel方法返回操作的sheet给newsheet
newnrows = e.get_nrows(newsheet)#对象调用类返回行数nrow给newrows
testdata = []
for i in range(1,newnrows):#循环读取excel中的测试用例,把用例加到testdata中生成二维数组
testdata.append(newsheet.row_values(i)) def reg_receive(url,data,headers):#定义发送的post请求
r = requests.post(url=url,data=json.dumps(data),headers=headers).json()
return r class Test_case(unittest.TestCase):
@classmethod #类函数,执行测试用例开始前执行
def setUpClass(cls):
print('接口测试开始') @classmethod #类函数,执行测试用例结束后候执行
def tearDownClass(cls):
print('接口测试结束') @parameterized.parameterized.expand(testdata)#testdata是存的excel中的测试case
def test_reg_receive(self,url,data,headers,expect,desc):
'''测试用例'''
self._testMethodName=desc#desc是对用例的描述
result = reg_receive(url,json.loads(data),json.loads(headers))
statuscode = result['statusCode']#返回状态码
self.assertEqual(int(expect),statuscode)#与测试用例中的状态码进行比对 # unittest.main()
bf = bf.BeautifulReport(unittest.makeSuite(Test_case))
bf.report(filename=testreport,description='接口测试报告')

python_自动化测试用例参数化的更多相关文章

  1. pytest自动化6:pytest.mark.parametrize装饰器--测试用例参数化

    前言:pytest.mark.parametrize装饰器可以实现测试用例参数化. parametrizing 1.  下面是一个简单是实例,检查一定的输入和期望输出测试功能的典型例子 2.  标记单 ...

  2. Python自动化测试用例设计--自动化测试用例与手工测试用例区别与联系

    1. 前言 手工测试用例是针对手工测试人员,自动化测试用例是针对自动化测试框架,前者是手工测试用例人员应用手工方式进行用例解析,后者是应用脚本技术进行用例解析,两者最大的各自特点在于,前者具有较好的异 ...

  3. 使用 Python 中 re 模块对测试用例参数化,进行搜索 search、替换 sub

    自动化测试用例,如果一百个接口要在Excel写100个sheet表单,每个接口有10个字段,里面有5个都可能是变化的,需要使用参数化,先试用特定的字符进行站位,在构造参数时在进行替换占位符: 一.用力 ...

  4. 用java和junit编写app自动化测试用例

    package myTest; import static org.junit.Assert.*; import io.appium.java_client.android.AndroidDriver ...

  5. 用python和unittest编写app自动化测试用例

    import unittest import webdriver import time class Test(unittest.TestCase): @classmethod def setUpCl ...

  6. 28. Python编写自动化测试用例

    接口文档已经提供了,requests库.unittest单元测试框架也已经介绍过,笔者相信读者朋友已经可以独立编写接口自动化测试用例了.但是有一些细节,我们需要聊一下.比如我们写登录接口测试用例,用户 ...

  7. 如何统计自动化测试用例的ROI 【投入产出比/投资回报率】

    一. 自动化测试的投入有哪些? 1. 自动化测试的软件平台投入 自动化测试平台的开发时间,实施时间. 2.  自动化测试的框架开发投入+框架维护的投入 开发自动化测试脚本使用的框架,例如通过一些现有框 ...

  8. selenium+python自动化97--unittest参数化(paramunittest)

    前言 paramunittest是unittest实现参数化的一个专门的模块,可以传入多组参数,自动生成多个用例 前面讲数据驱动的时候,用ddt可以解决多组数据传入,自动生成多个测试用例.本篇继续介绍 ...

  9. requests接口自动化-excel参数化

    在数据量大的时候,需要使用文件参数化. excel文件是其中一种. 安装xlrd读取excel文件.(这里是在pycharm安装) 发现选择豆瓣安装失败,阿里云安装成功. 准备excel文件,放在te ...

随机推荐

  1. Redis高级主题

    Redis高级主题   持久化 Redis 支持持久化, 其持久化数据有两种方式. 两种可以同时使用. 如果同时使用, Reids 在重启时将使用 AOF 方式来还原数据. RDB 按照一定策略定时同 ...

  2. LeetCode | DP专题详解

    221 medium     221. Maximal Square Medium Given a 2D binary matrix filled with 0's and 1's, find the ...

  3. CF235A 【LCM Challenge】

    这题好毒瘤啊 (特别是long long的坑,调了半天没调好!!)先将你特判一下小于3的话直接输出就是惹,不是的话就判断一下它能不能被2整除如果不能就直接输出n*(n-1)*(n-2)否则进行枚举枚举 ...

  4. LZH的多重影分身 qduoj 思维 差分

    LZH的多重影分身 qduoj 思维 差分 原题链接:https://qduoj.com/problem/591 题意 在数轴上有\(n\)个点(可以重合)和\(m\)条线段(可以重叠),你可以同时平 ...

  5. STM32程序内存分布

    参考文献:https://www.rt-thread.org/document/site/programming-manual/basic/basic/ 一般 MCU 包含的存储空间有:片内 Flas ...

  6. vue : 无法加载文件 C:\Users\lihongjie\AppData\Roaming\npm\vue.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 htt ps:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。 所在位置 行:1 字符: 1 + vue init webpack vue_p

    以管理员方式打开powershell 运行命令:set-ExecutionPolicy RemoteSigned 出现: 执行策略更改执行策略可帮助你防止执行不信任的脚本.更改执行策略可能会产生安全风 ...

  7. BIML 101 - ETL数据清洗 系列 - BIML 快速入门教程 - 将文本文件(csv)数据导进数据库

    第二节 将文本文件数据导进数据库 该小节介绍如何用BIML生成ssis包,将货币文本导入到数据库currency的表中. SSIS组件: Connection Manager组建管理connectio ...

  8. springboot JPA mysql

    官方文档 https://docs.spring.io/spring-data/jpa/docs/1.11.10.RELEASE/reference/html/ 常用关键字 通常,JPA的查询创建机制 ...

  9. java不同包中protected修饰的属性和方法调用方法

    protected修饰的静态属性和方法的调用方式1:直接类名调用 2:实例化父类对象进行调用 3:实例化子类对象进行调用 protected修饰的非静态属性和方法的调用方式:1:实例化子类对象进行调用 ...

  10. 在Powershell中使用Group-Object和-GroupBy

    使用Group-Object(group)按组统计 PS C:\> Get-Command -Module Microsoft.PowerShell.LocalAccounts | group ...