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. 提高十连测day3

    提高十连测day3 A 我们可以枚举两个 $ 1 $ 之间的相隔距离,然后计算形如 $ 00100100 \cdots $ 的串在原串中最⻓⼦序列匹配即可,复杂度 $ O(n^2) $ .寻找 $ S ...

  2. Hadoop hadoop(2.9.0)---uber模式(小作业“ubertask”优化)

    前言: 在有些情况下,运行于Hadoop集群上的一些mapreduce作业本身的数据量并不是很大,如果此时的任务分片很多,那么为每个map任务或者reduce任务频繁创建Container,势必会增加 ...

  3. Tkinter 之主窗口参数

    一.常用参数 语法 作用 window= tk.TK() 创建窗口 window['height'] = 300 设置高 window['width'] = 500 设置宽 window.title( ...

  4. docker install and minikube install

    1.选择国内的云服务商,这里选择阿里云为例 curl -sSL http://acs-public-mirror.oss-cn-hangzhou.aliyuncs.com/docker-engine/ ...

  5. LeetCode 222. 完全二叉树的节点个数(Count Complete Tree Nodes)

    题目描述 给出一个完全二叉树,求出该树的节点个数. 说明: 完全二叉树的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位 ...

  6. Flutter移动电商实战 --(41)详细页_数据接口的调试

    建立数据模型层,我们的业务逻辑分开,然后进行后台数据的调试 生成model类 json数据: { "code": "0", "message" ...

  7. Oracle 存储过程—为数传递变量

    oracle 存储过程的基本语法create or replace procedure proc1( p_para1 varchar2, p_para2 out varchar2, p_para3 i ...

  8. paint之文字示例

    package com.loaderman.customviewdemo; import android.content.Context; import android.graphics.Canvas ...

  9. SQL语句里合并两个select查询结果

    SQL UNION 操作符UNION 操作符用于合并两个或多个 SELECT 语句的结果集. 请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列.列也必须拥有相似的数据类型.同时,每条 ...

  10. 005-tomcat日志体系

    一.概述 首先了解java的日志体系 在JDK1.4后,sun公司增加了一个包为java.util.logging,简称为jul,用以对抗log4j. 后续还有很多日志门面方案,但是tomcat使用了 ...