接口自动化测试框架搭建(3、excel的设计&excel文件的读取)--python+HTMLTestRunnerCN+request+unittest+mock+db

目录

一、excel的构建

1、第一种设计方式

2、第二种设计方式

二、读取excel的方法封装


相关文章:

1、接口自动化测试框架搭建(1、环境、框架的思路及目录构成)--python+HTMLTestRunnerCN+request+unittest+mock+db

https://blog.csdn.net/Mojitoice/article/details/108992622

2、接口自动化测试框架搭建(2、配置文件&配置文件的读取)--python+HTMLTestRunnerCN+request+unittest+mock+db

https://blog.csdn.net/Mojitoice/article/details/109031074

 

hello,小伙伴,之前我有写过一个类似的文章,https://blog.csdn.net/Mojitoice/article/details/107020961

不同的地方就在于本次是已接口自动化测试框架为背景,如何构建一个excel以及封装读取excel的方法

一、excel的构建

对于不同的请求方式,我在这里有所区分,但实际中也会根据不同的业务场景进行增加,就比如请求接口需要登录态,可能就需要加上header这一列。如果没有对登陆态进行校验的话,就不需要加这列

1、第一种设计方式

举一个简单的例子嗷~

其中主要包括了,caseName,apiPath,apiName,priority(权重),method,purpose,params(post请求的body)

caseName:指测试用例的名称,可以是环境 + 接口 + 正常/异常case + 需要校验的字段 ,上面表格中的太过简单了。

apiPath:指api的路径,在这里写好是为了后续读取apiPath + 在config.ini中配置好的域名。从而得到具体的请求url

apiName:指接口的名称

priority :后续可以根据权重进行判断该用例是否需要执行。或者是否需要mock

method:请求的方式

purpose:期望返回值,这个可以是具体返回的json。也可以是一个值,看个人的需求。主要是用于之后的断言

params:post请求的body。

这种方式比较适合post请求,如果是get请求的话,还需要对params进行处理

2、第二种设计方式

caseName:指测试用例的名称,可以是环境 + 接口 + 正常/异常case + 需要校验的字段 ,上面表格中的太过简单了。

apiPath:指api的路径,在这里写好是为了后续读取apiPath + 在config.ini中配置好的域名。从而得到具体的请求url

apiName:指接口的名称

priority :后续可以根据权重进行判断该用例是否需要执行。或者是否需要mock

method:请求的方式

purpose:期望返回值,这个可以是具体返回的json。也可以是一个值,看个人的需求。主要是用于之后的断言

left_top_x_percent:是该接口url的请求参数

left_top_y_percent:是该接口url的请求参数

right_bottom_x_percent :是该接口url的请求参数

这种方式就比较适合get请求,直接读取到各种参数,拼接成url即可,如果是post请求的话,还需要转化为dict,然后json,然后进行请求。

 

二、读取excel的方法封装

该方法的路径为:/Users/dongyue/Documents/framework/testFile/readExcel.py

import os
from getPath import GetPath
from xlrd import open_workbook

#项目的绝对路径
path = GetPath().getPath()


class ReadExcel():
    def getexcel(self,excel_name,sheet_name):
        case_set = []
        excelpath = os.path.join(path,"excel",excel_name)  #拼接excel的路径
        excel = open_workbook(excelpath)  #excel对象
        sheet = excel.sheet_by_name(sheet_name)   #获取该excel的sheet
        rows = sheet.nrows  #获取该sheet的行数

        for i in range(rows):
            if sheet.row_values(i)[0] != 'case_name':
                case_set.append(sheet.row_values(i))
        return case_set

if __name__ == '__main__':
        print(ReadExcel().getexcel('Token.xlsx', 'Sheet1')

getPath 这个在之前的博文里~

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Pythonunittest库提供了一种基于单元测试的测试框架,是一个方便易用的Python测试框架。使用unittest库进行接口自动化测试可以提高测试效率和质量,本文将分享如何使用Python unittest搭建接口自动化测试框架。 第一步:安装Python unittest库 首先需要安装Python unittest库,Python unittest库是默认安装在Python中的,无需单独安装。 第二步:安装requests模块 接口自动化测试需要使用requests模块来发送HTTP请求、获取响应等操作,因此需要安装requests模块。使用pip安装requests命令如下: pip install requests 第三步:编写测试用例 使用unittest框架编写测试用例,首先需要导入unittest库并创建测试类,编写测试方法,方法名必须以test开头,并使用assert断言方法进行验证。例如: import unittest import requests class TestApi(unittest.TestCase): def test_get_users(self): url = 'http://localhost:8080/api/users' res = requests.get(url) self.assertEqual(res.status_code, 200) self.assertIsNotNone(res.json()) 第四步:执行测试用例 使用unittest框架执行测试用例,使用unittest.main()方法运行所有测试用例。例如: if __name__ == '__main__': unittest.main() 执行测试用例后,将输出测试结果,包括测试用例总数、成功数、失败数等。 第五步:持续集成 持续集成可以帮助实现自动化测试,可以将上述步骤集成到自动化测试框架中,提高测试效率和质量。使用持续集成工具,例如Jenkins,可以实现自动化测试的调度和执行,定期输出测试报告,是测试自动化化的不二选择。 在以上步骤中,请求地址和验证方法需要根据具体需求进行更改,但是编写测试用例的方法是类似的,熟练掌握unittest库可以快速搭建接口自动化测试框架,提高测试效率和质量。 ### 回答2: Python unittest requests 接口自动化测试框架搭建教程博客是指一篇博客文章,介绍如何使用Python unittestrequests库搭建接口自动化测试框架。该教程博客有如下几个方面: 1. 简单介绍Python unittestrequests库,以及它们在接口自动化测试中的使用; 2. 详细讲解如何安装Python unittestrequests库,并编写测试用例; 3. 讲解如何通过使用Python unittest的setUp()和tearDown()方法,在测试用例执行前后进行一些操作,以便更好地进行测试; 4. 介绍如何运行测试用例,并查看测试结果,以及如何进行测试报告生成; 5. 提供一些实例,展示如何使用Python unittestrequests库搭建接口自动化测试框架。 通过这篇教程博客,读者可以学习如何使用Python unittestrequests库搭建接口自动化测试框架,并且能够快速了解并掌握这种接口自动化测试方法的流程和基本方法。此外,该教程博客也提供一些实例,帮助读者更好地理解和应用这种方法。因此,这篇教程博客对于想要学习接口自动化测试以及深入了解Python unittestrequests库的读者来说,是一篇非常有价值的文章。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值