httprunner 4.x学习 - 6.debugtalk辅助函数的使用

发布时间 2023-05-09 10:00:58作者: 上海-悠悠

前言

httprunner 4.x 可以支持go语言和python语言写辅助函数,本篇主要介绍python语言写辅助函数。

debugtalk辅助函数

在项目根目录新建 debugtalk.py 文件写辅助函数可以实现自动化生成动态参数。

如下生成时间戳 和 随机字符串示例

# debugtalk.py

import time
import uuid


def current_time():
    """获取时间戳"""
    return time.strftime("%Y-%m-%d %H:%M:%S")


def rand_str():
    """生成随机字符串"""
    return str(uuid.uuid4())[:6]

在yaml 用例中引用函数

config:
  name: 引用变量

teststeps:
-
  name: post
  request:
    method: POST
    url: http://httpbin.org/post
    json:
      username: ${rand_str()}
      password: "123456"
  validate:
    - eq: [status_code, 200]

变量中也可以引用函数

config:
  name: 引用变量
  variables:
    user: ${rand_str()}

teststeps:
-
  name: post
  request:
    method: POST
    url: http://httpbin.org/post
    json:
      username: ${user}
      password: "123456"
  validate:
    - eq: [status_code, 200]

使用hrp 命令运行用例

>hrp run test_d.yml --gen-html-report

它会自动生成一个.debugtalk_gen.py 文件

# NOTE: Generated By hrp v4.3.3, DO NOT EDIT!

import sys
import os

sys.path.insert(0, os.path.dirname(os.path.abspath(__file__)))

from debugtalk import *


if __name__ == "__main__":
    import funppy
    funppy.register("current_time", current_time)
    funppy.register("rand_str", rand_str)
    funppy.serve()

此文件是自动生成的,不用管。

除了会生成.debugtalk_gen.py 文件, 从运行日志可以看到还会在C:\Users\你自己电脑用户名 目录生成一个.hrp文件

 expectValueType=int64 result=true
9:49AM INF run step end exportVars=null step=post success=true type=request
9:49AM INF run testcase end testcase="引用变量"
9:49AM INF quit hashicorp plugin process
2023-05-09T09:49:26.959+0800 [WARN]  grpc-py: plugin failed to exit gracefully
2023-05-09T09:49:26.972+0800 [ERROR] grpc-py: plugin process exited: path=C:\Users\dell\.hrp\venv\Scripts\python.exe pid=
17232 error="exit status 1"

查看运行报告