码迷,mamicode.com
首页 > Web开发 > 详细

jmeter--基于http+json接口的功能测试

时间:2018-02-01 00:16:33      阅读:920      评论:0      收藏:0      [点我收藏+]

标签:dem   rac   断言   failure   off   源码   tps   配置   方法   

jmeter--基于http+json接口的功能测试

测试项目叫做smile_task,简称sm_task。这是一个基于nodejs超简单的todo list,sm_task没有任何UI界面(纯接口),比较适合对接口测试进行学习了解。不过在进行接口测试之前,需要安装smile_task运行的环境:

  • mysql 
  • node 下载.msi版本,注意64位和32位的区别
  • cnpm(中国版nodejs的包管理器)

配置开发环境

安装coffee-script(可以通过coffee-script的语法来写javascript,coffee-script的终极目的就是将coffee-script脚本编译成javascript) and sequelize-cli (sequelize是一个orm库,通过sequelize-cli我们可以全局运行sequelize的migrate命令)

cnpm install -g coffee-script
cnpm install -g sequelize-cli

clone源码及安装依赖

git clone https://github.com/easonhan007/express_api_demo.git
cd express_api_demo
npm install #or cnpm install

配置数据库

  • 修改config/config.json中的数据库配置
  • 创建名为smile_task_development的数据库
sequelize db:migrate

运行

npm start

 

 

 

一、API:

smile_task提供了下面的一些api

1、无需鉴权

  • POST /login username/password # 登录
  • POST /register username/password/password_confirmation # 用户注册

2、需要鉴权

  • GET /api/tasks # 获取所有的task
  • GET /api/tastks/:task_id # 获取id为task_id的task
  • POST /api/tasks title/desc # 创建task
  • DELETE /api/tasks/:task_id # 删除id为task_id的task
  • PUT /api/tasks/:task_id # 完成id为task_id的task

二、jmeter示例:

1、用户注册

1.1、步骤详情:

"""
1、新建一个build-web-test-plan,删除线程组下除配置元件外的所有组件
2、在HTTP Request Defaults中填写smile_task服务器IP,Port
3、在线程组下新建Random Variable配置元件(名称: username、Variable Name: username、Output Format: user_000、Minimum Value: 1、Maximum Value: 999)
4、新建一个事务控制器,名称:case-注册
5、在事务控制器下,新建一个HTTP请求(名称: 注册、路径: /register、请求参数:
username: ${username}、password: ${username}、password_confirmation: ${username})
6、在线程组下添加1个查看结果树(ctrl+9)
7、在线程组下添加1个Debug Sample(ctrl+8)
8、将线程组中的所有数值改成1,点击运行
"""

2.2、效果图:

技术分享图片

3、如上图所示,在接口调试完毕后,可以在HTTP请求下新增后置处理器和断言(还可以考虑一些异常场景的case):

后置处理器获取用户名:

在"注册"这个HTTP请求下新建JSON PATH PostProcessor

  • 名称: 获取注册成功后返回的用户名
  • Variable names: returned_username
  • JSON Path expressions: $.username
  • Match Numbers: 1
  • Default Value: NOT FOUND

断言1 用户名不能为空:

新建JSR223 Assertion

  • 名称: 用户名不能为空
  • Language: javascript
  • Script:
 var returned_username = vars.get(‘returned_username‘);

  if(returned_username == ‘NOT FOUND‘){
    AssertionResult.setFailure(true);
    AssertionResult.setFailureMessage(‘没有返回用户名‘);
  }

断言2 返回用户名不正确:

新建JSR223 Assertion

  • 名称: 返回用户名不正确
  • Language: javascript
  • Script:
var returned_username = vars.get(‘returned_username‘);
var expected_username = vars.get(‘username‘);

if(returned_username != expected_username){
    AssertionResult.setFailure(true);
    AssertionResult.setFailureMessage(‘返回的用户名不正确‘);
}

  

 

2、用户登陆

1、步骤详情:

"""
1、新建一个事务控制器,名称:cese-登陆
2、在事务控制器下,新建一个HTTP请求,名称login:(方法:post、路径:/login   参数:username:username	:${returned_username}、password:${returned_username})
3、在login请求下新增一个后置处理器:JOSN Extractor(名称: 获取token、Variable names: returned_username、JSON Path expressions: $.username、Match Numbers: 1、Default Value: NOT FOUND)
4、在线程组下添加1个查看结果树(ctrl+9)
5、在线程组下添加1个Debug Sample(ctrl+8)
6、点击运行
"""

2、效果图:

技术分享图片

 

 3、创建任务、完成任务、删除任务、查看所有任务

1、步骤详情:

"""
后续这几个任务都需要鉴权(用户登陆时返回的token),才能通过服务器的认证,从而进行任务,因此需要从新设置一个HTTP信息头管理来接收保存token(Authorization: Bearer ${login_token})

创建任务:
1、新建一个事务控制器,名称:cese-创建 tasks
2、在事务控制器下,新建一个HTTP请求,名称POST tasks:(方法:POST、路径:/api/tasks   参数:title:${__RandomString(5, abcdefghijklmnopqrstuvwxyz)}、desc	:${__RandomString(10, abcdefghijklmnopqrstuvwxyz)}	)
3、在POST tasks请求下新增一个后置处理器:JOSN Extractor(名称: 获取task id、Variable names: task_id、JSON Path expressions: $.id、Match Numbers: 1、Default Value: NOT FOUND)
4、在线程组下添加1个查看结果树(ctrl+9)
5、在线程组下添加1个Debug Sample(ctrl+8)

完成任务:
1、新建一个事务控制器,名称:cese-完成 tasks
2、在事务控制器下,新建一个HTTP请求,名称PUT tasks:(方法:PUT、路径:/api/tasks/:${task_id}
3、在线程组下添加1个查看结果树(ctrl+9)
4、在线程组下添加1个Debug Sample(ctrl+8)

删除任务:
1、新建一个事务控制器,名称:cese-删除 tasks
2、在事务控制器下,新建一个HTTP请求,名称DELETE  tasks:(方法:DELETE、路径:/api/tasks/:${task_id}
3、在线程组下添加1个查看结果树(ctrl+9)
4、在线程组下添加1个Debug Sample(ctrl+8)

查看所有任务:
1、新建一个事务控制器,名称:cese-查看所有 tasks
2、在事务控制器下,新建一个HTTP请求,名称GET tasks:(方法:GET、路径:/api/tasks}
3、在线程组下添加1个查看结果树(ctrl+9)
4、在线程组下添加1个Debug Sample(ctrl+8)

"""

2、效果图:

技术分享图片

PS:默认情况下鉴权是关闭的。请确保app.coffee中的app.use(express_jwt(secret: jwt_secret).unless(path: [‘/register‘, ‘/login‘]))的这条语句没有被注释,然后使用coffee -c app.coffee重新编译。

 

jmeter--基于http+json接口的功能测试

标签:dem   rac   断言   failure   off   源码   tps   配置   方法   

原文地址:https://www.cnblogs.com/Keep-Ambition/p/8394905.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!