美文网首页
JMeter 接口测试(手工测试脚本)

JMeter 接口测试(手工测试脚本)

作者: 奶茶哥_lnc | 来源:发表于2018-09-04 21:44 被阅读0次

    接口测试的工具有很多,之前在另外一篇文章中写过用 Postman 做接口测试的 https://www.jianshu.com/p/fdfbf790927a,这次我们来学习用另外一个工具 JMeter 来做一个简单的接口测试。

    1、获取 API 信息

    API的方法:GET

    API的URL:https://api.seniverse.com/v3/weather/now.json

    API的参数:

    1. 请求参数:

      参数名 参数类型 参数意义 是否必选
      key string 你的API密钥 (需要自主到心知天气平台获取) true
      location string 查询的地理位置 true
      language string 结果表示的语言 false,默认简体中文
      unit string 结果表示的单位(华氏度,摄氏度) false,默认摄氏度

      location 参数值范围:

      代理位置有世界各地的,可以参考一份数据文档,链接:https://pan.baidu.com/s/1_LTRGVI799L-sfZyWbbIPA 密码:gk3t

      language 参数值范围:

      • zh-Hans 简体中文

      • zh-Hant 繁体中文

      • en 英文

      • ja 日语

      • de 德语

      • fr 法语

      • es 西班牙语

      • pt 葡萄牙语

      • hi 印地语(印度官方语言之一)

      • id 印度尼西亚语

      • ru 俄语

      • th 泰语

      • ar 阿拉伯语

      • 默认值:zh-Hans

      unit 参数值范围:

      当unit为c时

      返回值 单位
      温度 c(摄氏度)
      风速 km/h(千米每小时)
      能见度 km(千米)
      气压 mb(百帕)

      当unit为f时

      返回值 单位
      温度 f(华氏度)
      风速 mph(英里每小时)
      能见度 mi(英里)
      气压 in(英寸)
    2. 响应参数:

      参数名 参数类型 参数意义
      location 对象:包括id, name, country, path,timezone, timezone_offset
      now 对象:包括 text,code, temperature
      last_update 日期

      示例:

      {
       "results": [
           {
               "location": {
                   "id": "WS10730EM8EV",
                   "name": "深圳",
                   "country": "CN",
                   "path": "深圳,深圳,广东,中国",
                   "timezone": "Asia/Shanghai",
                   "timezone_offset": "+08:00"
               },
               "now": {
                   "text": "多云",
                   "code": "4",
                   "temperature": "29"
               },
               "last_update": "2018-09-04T19:20:00+08:00"
           }
       ]
      }
      

    2、编写用例脚本

    首先在 JMeter 的线程组下创建一个 HTTP 请求测试脚本,把 API 的信息填写完整。

    3、运行用例脚本

    然后在线程组下添加监听器--察看结果树,运行用例脚本。

    从上面的响应数据可以看到服务器成功返回了相对应的天气结果。

    4、用例断言

    返回响应数据后,接着对用例编写一个断言判断测试是否通过。下面我们以断言城市名称 name 参数为例对这个测试用例添加一个断言。

    4.1 编写断言

    断言的方式有很多,平时测试可以根据自己的需要选择不同的断言方式。

    这里我们选择 JSON Assertion 的方式,在请求下添加一个 JSON Assertion 断言。

    这里有几个配置项要设置一下:

    Assert JSON Path exists:要断言的 JSON 元素路径。其中请求响应数据的 JSON 对象换成了别名$, 路径的写法有2种,一种是$.results[0].location.name ,另外一种是$['results'][0]['location']['name']

    Additionally assert value:如果想让断言具有某些值,勾选复选框,这里我们勾选上。

    Expected Value:断言的值 。这里写上期望的 name 值:深圳。

    最后,在脚本下添加一个监听器--断言结果来监听断言的结果情况。

    4.2 查看断言结果

    添加断言后,再次运行一次用例脚本。

    从上图可以看出断言通过了。

    为了看断言失败的效果,故意改错请求中的 location 参数值。

    再发送一次请求。

    这次可以看到用例断言失败了。

    以上就是一个用 JMeter 工具做接口测试的简单例子,希望对初学者有用。

    相关文章

      网友评论

          本文标题:JMeter 接口测试(手工测试脚本)

          本文链接:https://www.haomeiwen.com/subject/nrnnwftx.html