首页 > 编程语言 >python接口自动化13-流量回放

python接口自动化13-流量回放

时间:2022-10-17 22:11:37浏览次数:80  
标签:13 name 回放 用例 python msgId -- key txt

@

目录


FastTester: 快速生成测试用例进行测试

简介

利用日常功能测试(实际也调用API)通过代理获取到API的请求与响应信息,将这些请求信息进行流量回放/锲约测试或快速生成用例,
可通过人工进行修改参数化提取、变量引用、断言等形成API自动化测试用例!


流程图(设计思路)

~_~ 不会画太粗糙了
在这里插入图片描述


快速开始

1.clone

github:git clone https://github.com/git-gsxl/FastTester.git

gitee:git clone https://gitee.com/qq772262624/FastTester.git

2.pip install:pip install -r requirements.txt -i https://pypi.douban.com/simple

3、demo运行测试:

cd tests
pytest
# Windows 可直接运行:`startCollect.cmd`

在这里插入图片描述


一、接口用例集合获取

方式一:Fiddler

1、将项目下utils/httpCat/fiddler.txt复制文本粘贴,FiddlerScript

2、更改为符合自己业务领域配置,是项目绝对路径app目录,注意要用两个扛\\
在这里插入图片描述

方式二:mitmproxy

1、将项目下utils/httpCat/config.ini过滤域名改为自己需要配置的域名以及业务领域

在这里插入图片描述

2、需要配置代理证书等,详看mitmproxy使用文档

3、运行文件:startCollect.cmd
如出现报错请检查 pip install -r requirements.txt 是否已安装?pip install mitmproxy==5.0.0

结合以上两种方式

1、你会得到:xxx.txt 文件

在这里插入图片描述

2、如需要用例入库,则执行命令行:

cd test
pytest --red_txt=true

另外可能需要进行数据库连接配置model/dbBase.py,默认为sqlite


二、执行测试

命令行参数说明(部分可在pytest.ini下默认配置),与pytest框架一致,并且新增以下参数:

  1. --env:查询业务领域=ppl及环境=test的用例

      如:--env=ppl,test                
    
  2. --param:附加将version参数替换为1或追加

      如:--param={\"version\":\"1\"}
    
  3. --file:读取app目录下所有txt文件进行流量回放,详细使用看流量回放

      如:--file=true                
    
  4. --red_txt:读取txt文件进行用例入库

      如:--red_txt=true        
    
  5. --init:db表结构初始化,一般不需要用到

      如:--init=true
    
  6. --key:企微或钉钉群推送的key

      如:--key=xxxx
    

方式1:流量回放,只回放API响应码为200

  cd tests
  
  1)方式1:默认为app目录下全部txt文件(以下2-3不存在文件时亦是):pytest --file=1
  
  2)方式2:指定app目录下的文件:pytest --file=fiddler_2022-7-31.txt
  
  3)方式3:绝对路径指定文件(注意win下需要\\):pytest --file=E:\\fiddler_2022-7-31.txt
  
  4)方式4:相对路径指定文件:pytest --file=./fiddler_2022-7-31.txt

方式2:经过用例入库,执行db用例测试

cd tests
pytest test_playback.py --env=domain,env --param={\"version\":\"1\"}

ps:Windows可以默认ini参数直接一键运行并生成报告:testStart.cmd
(支持替换变量,存储变量,引用变量,响应断言)


三、后置处理器介绍:http_collect

参数提取器,默认是取第1个值(支持提取response与headers接口的返参)
Jsonpath语法请参考:https://goessner.net/articles/JsonPath

1.Jsonpath 区分大小写

1)获取key的值:['key'] ----> {'key':'value'}

2)获取key的值并重新命名:[{'key':'name'}] ----> {'name':'value'}

3)获取key的值并指定取第n个:['key':n] ----> {'key':values[n]}

4)获取key的值并重新命名及指定取第n个:['key':['name',n]] ----> {'name':values[n]}

5)原生Jsonpath语法:['$.data.key'] ----> {'key':'value'}

6)原生Jsonpath语法并重新命名:[{'$.data.key':'name'}] ----> {'name':'value'}

7)原生Jsonpath语法并指定取第n个:[{'$.data.key':n}] ----> {'key':values[n]}

8)原生Jsonpath语法并重新命名及指定取第n个:[{'$.data.key':['name',n]}] ----> {'name':values[n]}

2.正则表达式

1)获取正则表达式的值并命名为env:[{'re':['env','http://(.+?)/']}] ----> {'env':'value'}

2)获取正则表达式的值并命名为env及取第n个值:[{'re':['env','http://(.+?)/', -1]}] ----> {'name':'value'}


四、断言使用介绍:http_assert

1.Jsonpath 断言

1.字符在里面:["msgId"]

  `实际为:assert "msgId" in response.text`

2.变量在里面:["${msgId}"]

`实际为:assert "${msgId}" in response.text`

2.字符相等:[{"msgId":"123456"}]

`实际为:assert 123456 == json_path(result.json(), 'msgId')`

3.字符在里面or其它:[{"msgId":["123456","in"]}] 注:in 可以是== != not in

assert 123456 in response.get('msgId')

4.长度:1 == len(response.get('msgId')):[{"msgId":[1,"len"]}]

assert 1 == len(response.get('msgId'))

2.正则表达式断言

1.直接写正则表达式即可,如:[{'re':'http://(.+?)/'}]


五、变量引用

使用本系统且遵循Faker语法直接引用:${Faker语法}

ppl_开头,为自定义生成数据方法

Faker 更多请查阅官方文档:https://faker.readthedocs.io/en/stable/locales/zh_CN.html#faker-providers-address

1.号码相关:

1)手机号:${phone_number}
18520149907

2)身份证号码:${ssn}
410622198603154708

2.时间日期相关

1)当前日期时间:${ppl_now_datetime}
2022-07-02 12:56:58

2)当前时间戳:${ppl_time}
1656737818

3)当前日期:${ppl_now_date}
2022-07-02

4)当前时间:${ppl_now_time}
12:56:58

5)过去7天的日期时间:${ppl_datetime(-7)}
2022-06-25 00:00:00

6)未来7天的日期时间:${ppl_datetime(7)}
2022-07-09 23:59:59

7)随机年-月-日:${date}
1996-03-20

8)随机(时:分:秒):${time}
04:52:23

9)未来的日期时间:${future_datetime(end_date=+7d)}
2022-07-07 16:01:23

10)过去的日期时间:${past_datetime(end_date=-7d)}
2022-06-29 13:29:20

3.名字相关:

1)姓名:${name}
王凯

2)姓名(女):${name_female}
戴丽丽

3)姓名(男):${name_male}
刘荣

4)姓:${last_name}

5)名字:${first_name}

4.地址相关

1)地址:${address}
香港特别行政区大冶县上街钟街k座 664713

2)省:${province}
河北省

3)市:${city}
长春县

4)地区:${district}
白云

5)街道地址:${street_address}
武汉街D座


六、数据库config配置说明

默认使用sqlite,一般只需要连接sqlite更改1、账号环境配置信息即可

在这里插入图片描述

1.账号环境配置

  1) gray:默认就好,一般会使用如:AB测试模型使用,定制化区分环境
  2) Tester:登录获取token或cookie初始化,可配置多个登录信息,如下有两种例子:
        collects:表示后置处理器 collect (使用详细查看第三点),用例提取token或cookie作为登录态
  {
      "gray":"gray",
      "Tester":[
          {
              "https://app-xxx.com":{
                  "url":"api/user/login",
                  "json":{
                      "mobile":18888888888,
                      "Password":"mVs6NwvIFRgN0aaUo4KZOiW9QZWbKZjqVX1eW9Gr2s4rgZ5atS3ppY39ZlyE37Tb2/zo6YWJV6VJV="
                  },
                  "method":"POST",
                  "collects":["clienttoken"]}
          },
          {
              "https://web-xxx.com":{
                  "url":"/api/index.php?r=data/login",
                  "data":"user=admin&password=4076f862096d1536b6cac6866e386655=",
                  "method":"POST",
                  "headers":{"content-Type":"application/x-www-form-urlencoded"},
                  "collects":["ppl_cookie"]
              }
          }
      ]
  }

2.默认配置 (domain=default)

  1) filter_path:过滤path为列表的,如登录/退出登录接口
  2) filter_code:根据返回retCode字段,判断是否=0或='0',是则数据符合,否则跳过该数据
  3) re_list:一般不需要使用,如AB测试模型时,则根据业务情况配置从response(uri/body/header)中正则匹配
  4) db_pop:获取用例过滤:数据库字段转dict,去除非必要的字段,默认就好
  5) filter_headers:过滤不必要的headers,默认就好
  6) split_url_handle:path不需要特殊处理可默认,一般php接口可能需要处理,如下
        例子:"split_url_handle":{".php":"path + '?r=' + query.pop('r')"}
        表示:如果'.php'在path中,则运行path=eval("path+'?r='+query.pop('r')"
   {
       "filter_path":[
           "/user/logout",
           "/user/login"
       ],
       "filter_code":{"retCode":[ 0, "0" ]},
       "re_list":[],
       "db_pop":[
           "id","curl","response",
           "_sa_instance_state",
           "create_time","update_time"
       ],
       "filter_headers":[
           "content-length","accept-encoding","host","user-agent","accept",
           "origin","referer","sec-ch-ua","connection","sec-fetch-dest",
           "sec-fetch-mode","sec-fetch-site","pragma","accept-language",
           "sec-ch-ua-mobile","sec-ch-ua-platform","postman-token",
           "cache-control","x-requested-with","accept-encoding"
       ],
       "split_url_handle":{}
   }

如有建议/疑问请联系我:https://blog.csdn.net/qq_42675140

标签:13,name,回放,用例,python,msgId,--,key,txt
From: https://www.cnblogs.com/gsxl/p/16800915.html

相关文章

  • python爬虫从0到1 -urllib_Cookie登录
    前言当我们进行某项数据采集的时候,有时会让我们进行登录,那我们要怎样去解决这个问题呢?为了不让我们爬取这些数据,又采取了怎么样的反爬措施呢?下面就让我们带着这些问题去一探......
  • Python与JavaScript交互
    介绍“胶水”语言Python很擅长于其他语言交互,本文介绍如何与JavaScript来交互。 ......
  • Python 遍历指定文件夹下所有文件批量操作的方法
    Python中进行程序开发时,有些文件操作的需求可能需要我们对文件夹下的所有文件进行批量操作。本文主要介绍一下Python中对指定文件夹下所有文件进行批量操作的方法。原文地......
  • python当中删除文件的几种方法
    python当中运用os,shutil来实现对文件和文件夹的删除操作。方法一:importos,shutildefdel_file0(path):shutil.rmtree(path)del_file0(r"C:\Users\1\Desktop\m......
  • Python __new__()方法详解
    __new__()是一种负责创建类实例的静态方法,它无需使用staticmethod装饰器修饰,且该方法会优先__init__()初始化方法被调用。一般情况下,覆写__new__()的实现将会使用合......
  • Python导入模块,Python import用法(超级详细)
    使用 Python 进行编程时,有些功能没必须自己实现,可以借助Python现有的标准库或者其他人提供的第三方库。比如说,在前面章节中,我们使用了一些数学函数,例如余弦函数cos()......
  • 什么是文件路径,Python中如何书写文件路径?
    当程序运行时,变量是保存数据的好方法,但变量、序列以及对象中存储的数据是暂时的,程序结束后就会丢失,如果希望程序结束后数据仍然保持,就需要将数据保存到文件中。Python 提......
  • Python(for和while)循环嵌套及用法
    Python 不仅支持if语句相互嵌套,while和for循环结构也支持嵌套。所谓嵌套(Nest),就是一条语句里面还有另一条语句,例如for里面还有for,while里面还有while,甚至while......
  • Python zip函数及用法
    zip()函数是 Python 内置函数之一,它可以将多个序列(列表、元组、字典、集合、字符串以及range()区间构成的列表)“压缩”成一个zip对象。所谓“压缩”,其实就是将这些......
  • Python continue的用法
    和break语句相比,continue语句的作用则没有那么强大,它只会终止执行本次循环中剩下的代码,直接从下一次循环继续执行。仍然以在操作跑步为例,原计划跑10圈,但当跑到2圈半......