• jmeter(二十八)利用beanshell进行多重断言


    在接口测试中,我们对返回结果的正确性判断一般是基于响应报文的返回内容进行断言。但有些时候,按照正常的业务逻辑来说,一个请求返回的内容是多种不同的。

    比如:用户注册功能,注册成功是正常的返回message;该用户已注册,也是正常的业务逻辑。但响应报文的message和code/status往往是不一样的。

    这篇博客,介绍下如何利用jmeter的beanshell断言,来处理这种请求。。。

     

    一、响应断言

    以用户注册功能作为例子,从下面两种场景来进行接口测试:

    1、假设用户不存在,接口设计逻辑,注册成功返回的内容是这样:

    {"code":200,"msg":"success"},"status":200}

    响应断言应该如下配置:

    返回的结果是这样:

    2、假设用户已存在,那么在测试该功能时,使用响应断言,返回的内容如下:

    从业务逻辑来说,无论注册成功还是用户已存在,这都是正常的业务场景。

    但响应断言只能判断“是”或者“否”,如果需要验证业务正确而非技术正确,如何做呢?

    我们可以利用beanshell断言,来满足我们的需求。

    二、beanshell断言

    还是针对上述场景,无论注册成功,还是用户已存在,我们都判定接口返回正确,那么beanshell断言,可以如下配置:

    返回的结果是这样:

    附:beanshell断言代码demo:

    import com.alibaba.fastjson.JSONObject;
    import com.alibaba.fastjson.JSON;
    
    String result=SampleResult.getResponseDataAsString();
    
    JSONObject jsonObject=JSON.parseObject(result);
    int code=jsonObject.getIntValue("code");
    JSONObject data=jsonObject.getJSONObject("data");
    
    log.info("code:"+code);
    
    if(code==200||code>=20000000){
        SampleResult.setSuccessful(true);
    }

    内容仅供参考,请根据具体场景和接口设计逻辑,使用beanshell断言。。。

  • 相关阅读:
    删除购物车列表页面商品
    购物车页面修改数量功能实现
    cookie来实现购物车功能
    wxWidgets学习计划
    正则校验表达式
    Vue组件间的参数传递与Vue的路由实现
    Vue实现数据双向绑定的原理
    Vue的生命周期
    对于mvvm的理解
    vue+axios 前端实现登录拦截的两种方式(路由拦截、http拦截)
  • 原文地址:https://www.cnblogs.com/imyalost/p/12777912.html
Copyright © 2020-2023  润新知