软件测试用例包括_白盒测试用例

软件测试用例包括_白盒测试用例测试用例分层每个测试用例都有1个或多个测试步骤(List[step]),每个测试步骤对应一个API请求或其他用例的引用。从上图分析,我们可以看到testsuite中包含了3个测试用例,testca

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

测试用例分层

每个测试用例都有1个或多个测试步骤(List[step]),每个测试步骤对应一个API请求或其他用例的引用。
软件测试用例包括_白盒测试用例
从上图分析,我们可以看到testsuite中包含了3个测试用例,testcase1中有4个请求和一个步骤teststep12,其中步骤teststep12依赖testcase2,testcase2中的步骤teststep22又依赖于testcase3。
举例说明:模仿上面的用例,我们也写3个用例

  • testcase1:以最便宜的价格购买一瓶可口可乐(testcase1中的其中一个步骤需要调用testcase2)
  • testcase2:查询价格最低的250ml可口可乐,并进入首页(testcase2中的其中一个步骤需要调用testcase3)
  • testcase3:登录用户user1成功

注意

为了简单,在HttpRunner v2.x中的API概念已经被取消了。你可以将API定义为只有一个请求步骤的测试用例。
 

测试用例的分层思想:

  • 测试用例(testcase)应该是完整且独立的,每条测试用例应该是都可以独立运行的(重要)
  • 测试用例是测试步骤(teststep)的有序集合
  • 测试用例集(testsuite)是测试用例的无序集合,集合中的测试用例应该都是相互独立,不存在先后依赖关系的,可以无序执行
     

RunRequest

    teststeps = [
        Step(
            RunRequest("get with params")
            .with_variables(
                **{"foo1": "bar11", "foo2": "bar21", "sum_v": "${sum_two(1, 2)}"}
            )
            .get("/get")
            .with_params(**{"foo1": "$foo1", "foo2": "$foo2", "sum_v": "$sum_v"})
            .with_headers(**{"User-Agent": "HttpRunner/${get_httprunner_version()}"})
            .extract()
            .with_jmespath("body.args.foo2", "foo3")
            .validate()
            .assert_equal("status_code", 200)
            .assert_equal("body.args.foo1", "bar11")
            .assert_equal("body.args.sum_v", "3")
            .assert_equal("body.args.foo2", "bar21")
        ),

从上述代码可知,teststeps中的RunRequest用于发送API请求和对响应结果进行提取和断言
下面详细介绍里面各个方法的作用
 

RunRequest(name)

RunRequest的参数名用于指定teststep名称,它将显示在执行日志和测试报告中。
RunRequest("get with params")这个步骤的名称就是get with params
 

.with_variables

设置测试步骤的变量。每个测试步骤的变量都是独立的,如果想在多个测试步骤中共享变量,需要在config variables中定义。
注意:如果config variables和.with_variables里有重名的变量,那么当你引用这个变量的时候,Step变量会覆盖config变量。
 

.method(url)

设置http请求方法,比如get、post、put、patch、delete等等,后面再跟上路径
注意:如果base_url在config中设置了,url只能是相对路径部分。

# 用get方法访问路径为/getTime(相对路径)
.get("/getTime")

# 用post方法访问路径id=3(绝对路径)
.post("http://www.baidu.com/getTime")

 

.with_params

设置url的query,以键值对的形式,相当于requests.request 中的params。

.with_params(**{"foo1": "$foo1", "foo2": "$foo2", "sum_v": "$sum_v"})

 

.with_headers

设置请求的headers,相当于requests.request 中的headers。

.with_headers(**{"User-Agent": "HttpRunner/${get_httprunner_version()}"})

 

.with_cookies

设置Http请求cookies,相当于requests.request 中的cookies。
 

.with_data

设置Http的请求Body,相当于requests.request 中的data。

.with_data("foo1=$foo1&foo2=$foo2&foo3=$foo3")

 

.with_json

设置Http请求json格式的Body,相当于requests.request 中的json。

.with_json({"foo1": "foo1", "foo2": "foo2", "foo3": "foo3"})

 

.extract

利用jmespath提取Json Response body内容,

.with_jmespath(jmes_path: Text, var_name: Text)

.validate

断言,我们测试最终就是要验证接口返回是否符合预期。
格式:

assert_XXX(jmespath: Text, expected_value: ANy, message: Text="")

下图展示HttpRunner内置断言:
软件测试用例包括_白盒测试用例

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/165095.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 介绍篇 决策引擎环节

    介绍篇 决策引擎环节决策引擎概念简述在我理解上决策引擎类似是一个管道、运输系统,连通整个风控流程,所有的规则和评分卡以及流程都覆盖其中,分配到每一个环节(比如人工),将结果返回给决策引擎,走入下一个流程决策引擎的使用规则决策引擎的分流效果评分卡是内置在决策引擎当中,基于评分卡的分段,评分卡的使用具体参见:评分卡在策略中的使用,进行分流,分流决策的目的是为让好客户以及有借款欲望客户进一步走入下一流程决策引擎…

  • html5设置table样式_原生js添加样式

    html5设置table样式_原生js添加样式table样式设置表格:._table{width:100%;border-collapse:collapse;border:0px;}设置表头:._tabletheadtr{font-size:13px;color:#2e3b45;text-align:center;background-color:rgba(230,255,250,0.92);…

  • js数组排序—自定义快速排序

    js数组排序—自定义快速排序数组自带的sort方法 vararr=[3,4,2,1]; arr.sort(); console.log(arr);进行递增排序(4)[1,2,3,4]sort方法可以接收一个参数,用来自定义排序规则 arr.sort(function(val1,val2){ //returnval1-val2;默认 returnval2-…

  • 降维

    降维

  • 请简述Map-Reduce算法的原理(通俗易什么成语)

    下面是我自己的微信公众号(不定期更新JAVA、大数据、个人成长等干货)1、公众号上有经典的技术电子书可以免费领2、大家有问题可以在公众号问我,只要你问了我就会回复(相互交流)也可以扫描下面二维码,加我个人微信,和我直接沟通Hadoop简介Hadoop就是一个实现了Google云计算系统的开源系统,包括并行计算模型Map/Reduce,分布式文件系统HDFS,以及…

  • DDR中的ODT_DDR SDRAM

    DDR中的ODT_DDR SDRAMODT电阻端接

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号