Action模块

封装接口request方法,根据传入的参数调用不同的请求方法,因为项目特色,我们公司的接口都是get和post方法,所以仅仅封装了get和post方法:

import requests
import json
from Util.Log import *
import traceback
def api_request(method,baseurl,header,auth,body,test_case_name):
"""Action关键字,通过method确认使用get还是post方法,baseurl为请求路径,header为空请求头,auth为授权登录信息,body为当请求方法为post的时候请求data信息"""
# global response
default_header = {'Content-Type':'application/json'}
# 如果没有提供请求头信息,则使用默认请求头信息
if not header:
header = default_header
# 如果有头信息,因为excel里面读出来的都是字符串,需要将头信息转换为字典
#get请求
if method.lower() =="get":
try:
if isinstance(body, dict):
info("-"*80)
info("请求接口操作是:%s"%test_case_name)
info("请求的接口地址是:%s" % baseurl)
info("请求的数据是:%s" % body)
r = requests.get(baseurl, params=body,headers=header,auth=auth)
info("请求返回状态码:%s"%r.status_code)
else:
# r = requests.get(baseurl + str(body),headers=header,auth=auth)
r = requests.get(baseurl,headers=header,auth=auth)
info("-"*80)
info("请求接口操作是:%s"%test_case_name)
info("请求的接口地址是:%s" % baseurl)
info("请求的数据是:%s" % body)
info("请求返回状态码:%s"%r.status_code)
return r
except Exception as e:
# print("进入Exception")
info("get 方法请求发生异常:请求的 url 是 %s,请求的内容是%s\n发生的异常信息如下:%s" % (baseurl, body, traceback.format_exc()))
r = None
return r
#post请求
elif method.lower()=="post":
try:
if isinstance(body, dict):
info("-"*80)
info("请求接口操作是:%s"%test_case_name)
info("请求的接口地址是:%s" % baseurl)
info("请求的数据是:%s" % json.dumps(body))
r = requests.post(baseurl,headers = header,data=json.dumps(body),auth=auth)
info("请求返回状态码:%s"% r.status_code)
else:
raise ValueError
except ValueError as e:
info("post 方法请求发生异常:请求的 url 是 %s,请求的内容是%s\n发生的异常信息如下:%s" % (baseurl, body, "请求参数不是字典类型"))
r = None
except Exception as e:
info("post 方法请求发生异常:请求的 url 是 %s,请求的内容是%s\n发生的异常信息如下:%s" % (baseurl, body, traceback.format_exc()))
r = None
return r

详解:

因为项目特点,post方法的'Content-Type'是'application/json',所以我在封装的请求方法里面封装了默认header.同时加入了写log的代码便于以后的bug追溯。

Request方法接收6个参数,分别是

  1. Method:请求方法名字,
  2. Baseurl:请求url
  3. header:请求头
  4. auth:验证信息
  5. body:请求body
  6. test_case_name:请求接口名称,主要是用与写日志记录接口名称

根据传入的请求method选择进行get或者post请求,如果是get方法则提供请求url,请求header,请求授权;如果是post方法则提供请求url,请求头,请求体,请求授权;

在请求之前进行数据的处理,包括如果没有提供请求头的话使用默认请求头,转换请求体为json格式等处理。

在进行请求的操作的时候进行日志记录,记录格式为:

2019-10-11 11:20:57 Log.py[line:30] INFO --------------------------------------------------------------------------------
2019-10-11 11:20:57 Log.py[line:30] INFO 请求接口操作是:*******
2019-10-11 11:20:57 Log.py[line:30] INFO 请求的接口地址是:http://*********************************
2019-10-11 11:20:57 Log.py[line:30] INFO 请求的数据是:*********

20191011-构建我们公司自己的自动化接口测试框架-Action的request方法封装的更多相关文章

  1. 20191011-构建我们公司自己的自动化接口测试框架-testrun最重要的模块

    testrun模块呢就是最终自动化测试入口,调用前面封装的各个模块主要流程是: 1. 获取测试集种待执行的测试用例 2. 处理测试用例获取的数据,包括转换数据格式,处理数据的中的关联等 3. 处理完数 ...

  2. 20191011-构建我们公司自己的自动化接口测试框架-Util的ClearData模块

    cleardata模块主要是用于在每次测试之前清除历史执行痕迹,主要代码如下: from Util.ParseExcel import * from ProVar.ProjConfigVar impo ...

  3. 20191011-构建我们公司自己的自动化接口测试框架-Util的AssertResult模块

    AssertResult主要就是进行结果断言的了,因为断言结果分2种情况,一种是断言词,一种是断言sheet,如果涉及断言sheet,则需要操作excel到对应的断言表断言所有的字段并且书写断言结果主 ...

  4. 20191011-构建我们公司自己的自动化接口测试框架-Util的TestDataHandler模块

    TestDataHandler模块主要是做测试数据的处理,包括转换数据格式和变量参数处理转换数据格式函数: data是数据,data以$()的方式识别变量,如果请求的数据有变量,则将变量用global ...

  5. 20191011-构建我们公司自己的自动化接口测试框架-Util的getTestSuite模块

    getTestSuite主要是用于在testData里面获取测试集以及对应的测试数据,包括2个主要的方法,一个是获取测试集,一个是获取测试集里面要执行的测试用例 获取测试集方法: from Util. ...

  6. 20191011-构建我们公司自己的自动化接口测试框架-Util的htmlreport模块

    生成htmlreport的模块是我在网上随意找的一个版本,主要生成的report包括接口名称,接口url,请求数据,响应数据,断言词,断言结果等 具体的htmlreport代码如下: # -*- en ...

  7. 20191011-构建我们公司自己的自动化接口测试框架-Util的读取excel常用方法模块

    包括获取excel的sheet名字,设定excel的sheet,读excel,写excel等常规操作. from openpyxl import Workbook from openpyxl impo ...

  8. 20191011-构建我们公司自己的自动化接口测试框架-ProVar模块

    ProVar模块主要定义测试数据所在目录,以及定义变量和测试数据excel里面的column对应这样后续在进行excel操作的时候直接使用变量即可进行操作,后期excel的column有增删的时候,修 ...

  9. 20191011-构建我们公司自己的自动化接口测试框架-Config配置

    Config模块主要是为了存放的一些其他配置等的一个目录,当前目录存放日志配置文件 ################################################ [loggers] ...

随机推荐

  1. Comet OJ - Contest #6 B.双倍快乐(二维最大上升子序列和)

    双倍快乐 题目描述 Illyasviel:"你想要最长不下降子序列吗?" star-dust:"好啊!" Illyasviel:"老板,给我整两个最长 ...

  2. Git .gitignore中已添加文件路径,但仍未被忽略

    当文件之前已经被提交到仓库后,后面即使将文件路径添加到 .gitignore ,使用 git status 命令,依然会看到文件被修改. $ git status 位于分支 master 您的分支与上 ...

  3. 解决GitHub上传大于100M文件失败

    目录 问题 解决 参考 问题 push的时候遇到以下问题: remote: error: GH001: Large files detected. You may want to try Git La ...

  4. T-MAX-凡事预则立

    T-MAX-凡事预则立 这个作业属于哪个课程 2019秋福大软件工程实践Z班 这个作业要求在哪里 团队作业第五次-项目冲刺 团队名称 T-MAX 这个作业的目标 1.冲刺的时间计划安排2.答辩问题的回 ...

  5. oneway modifier MQ 发送请求不接受任何响应

    Apache Thrift - Home http://thrift.apache.org/ /** * This method has a oneway modifier. That means t ...

  6. mysql数据库分库分表(Sharding)(转)

    mysql数据库切分 前言 通过MySQLReplication功能所实现的扩展总是会受到数据库大小的限制.一旦数据库过于庞大,尤其是当写入过于频繁,非常难由一台主机支撑的时候,我们还是会面临到扩展瓶 ...

  7. DTC & MSDTC (待研究)

    相关学习文档: Database Systems: The Complete Book

  8. Springboot集成MapperFactory(ma.glasnost.orika.MapperFactory)类属性复制

    一.导入Jar() gradle方式 compile group: 'ma.glasnost.orika', name: 'orika-core', version: '1.5.1' maven方式 ...

  9. 一秒 解决 ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql 问题

    提示:ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'.前两天也出现过这个问题,网上找了一个比 ...

  10. Ubuntu 16.04 haproxy 简单配置应用

    HAproxy HAProxy是一个使用C语言编写的自由及开放源代码软件,其提供高可用性.负载均衡,以及基于TCP和HTTP的应用程序代理.   测试环境 ubuntu16.04 192.168.20 ...