• 框架选择
    • Super Test:基本的HTTP请求,返回判断
    • Chai:对返回的结果进行判断
    • grunt:集成jenkins
    • grunt-mocha-test:grunt任务
  • Jenkins环境配制
    • 使用Jenkins调度mochaTest任务,并配制结果输出相关

    • 执行环境配制
      • 多个环境之间的自动切换:export NODE_ENV=dev && cd api-test && grunt
    • PS:若需要指定地址执行时,仅需要把local修改需要的目标地址即可
  • 小样例
    • 测试:访问http://www.baidu.com时,返回的状态码是否为200(成功)

      • 修改endpoints.js中local地址为:http:www.baidu.com
      • 修改Gruntfile.js中src为:test/module/demo.js
      • 在module目录下新创建文件demo.js
      •  var config = require('../config/endpoints'),
        request = require('supertest')(config.host[config.env]); describe('测试访问baidu首页.', function() {
        it('返回状态码为200.', function(done) {
        request.get('/')
        .expect(200)
        .end(done);
        }); });
      • 进入到api-test目录,运行grunt
      • ➜  api-test git:(master) ✗ grunt
        Running "mochaTest:test" (mochaTest) task 测试访问baidu首页.
        ✓ 返回状态码为200. (958ms) passing (964ms) Done, without errors.
    • 测试(失败):访问http://www.baidu.com时,返回的状态码是否为201
      • 修改demo.js文件
      •  var config = require('../config/endpoints'),
        request = require('supertest')(config.host[config.env]); describe('测试访问baidu首页.', function() {
        it('返回状态码为200.', function(done) {
        request.get('/')
        //此处失败
        .expect(201)
        .end(done);
        }); });
      • 执行测试:grunt
      • ➜  api-test git:(master) ✗ grunt
        Running "mochaTest:test" (mochaTest) task 测试访问baidu首页.
        ) 返回状态码为200. passing (2s)
        failing ) 测试访问baidu首页. 返回状态码为200.:
        Error: expected "Created", got "OK" Warning: Task "mochaTest:test" failed. Use --force to continue. Aborted due to warnings.
      • 分析:expect(201)为期待的状态码为201,但实际返回的状态码为200。此处可为测试的验证点
  • 强化
    • 一次执行N个js文件

      • 修改Gruntfile.js中src即可
    • 设置请求的header
      • request.get('/')
        .set('Content-Type','application/json')
    • 设置post请求的数据
      •  request
        .post('/post/data')
        .send({
        "A": 1,
        "B": 2
        })
    • 对expect进行调整:如预期返回body中totalCount为6
      • .expect(function(res){
        //返回中totalCount为6
        if (!(res.body.totalCount.should.equal(6))) throw new Error("总数不对");
        })

总结-测试规划

  • 一个js文件针对单个接口请求进行测试
  • 一个it仅测试一个接口功能
  • 按文件夹来划分功能模块,按js文件来划分API请求

API测试-Super Test的更多相关文章

  1. API测试

    API(Application Programming Interface)包含: 单元测试(Unit Testing).模块测试(Module Testing).组件测试(Component Tes ...

  2. 使用python+pychram进行API测试(接口测试)初级STEP 1

    花了一天时间安装了解了下最基本的python+pychram进行API测试,下面这个可以指导自己以后入门:基本的开发级别还需要学习 1.python下载地址:https://www.python.or ...

  3. Chrome Restful Api 测试工具 Postman-REST-Client离线安装包下载,Axure RP Extension for Chrome离线版下载

    [Postman for Chrome 离线下载] Postman-REST-Client离线安装包,可直接在Chrome浏览器本地安装使用,可模拟各种http请求,Restful Api测试, CS ...

  4. 接口API测试和返回值JSON解析的插件

    火狐插件1.   HttpRequest作用:接口API测试例子:http://192.168.10.61:8080/ZHCS/user/loginApp.do?phone=admin&pwd ...

  5. asp.net web api 测试帮助页面建立并测试

    asp.net web api 测试帮助页面建立并测试 现在使用WEB API来开发,越来越流行. 在开发过程中的测试调试,可以使用Fiddler等工具来帮助测试外,还有: 在asp.net 中有种方 ...

  6. Aliexpress API 测试工具

    Aliexpress API 测试工具 上回简单说了 Aliexpress API 的认证流程, 这回在奉送一个小工具, API 测试工具. 点我下载 做这一行,和做程序员的生活完全不搭调, 格格不入 ...

  7. API测试自动化——基于CDIF的SOA基本功能(实例篇)

    今天我们通过一些实例来体验一下API的自动化测试,感受一下基于CDIF的SOA的一些基本功能. 传统的测试工具在测试一个API的时候,必须手动填写这个API所需要接收的所有信息,比如一个查询航班动态的 ...

  8. 开源API测试工具 Hitchhiker v0.4更新 - 没有做不到,只有想不到

    Hitchhiker 是一款开源的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起管理Api. 详细介绍 ...

  9. 开源API测试工具 Hitchhiker v0.5更新 - 完善细节

    Hitchhiker 是一款开源的支持多人协作的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起管理Ap ...

  10. 开源API测试工具 Hitchhiker v0.6更新 - 改进压力测试

    Hitchhiker 是一款开源的支持多人协作的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起协作测试 ...

随机推荐

  1. Odoo 中的 Controller

    来自  Odoo处理HTTP请求的接口用的Contoller类,封装于web模块中. --------------------------------------------------------- ...

  2. 使用Word发布文章到 WordPress 博客

    使用Word发布文章到 WordPress 博客 我们都知道,WordPress 自带的编辑器功能比较弱,而使用 Word 编辑文档却功能强大.其实我们使用 Word 编辑好的文档也是可以直接发布到 ...

  3. jQuery小节

    jQuery 语法 jQuery 选择器 在前面的章节中,我们展示了一些有关如何选取 HTML 元素的实例. 关键点是学习 jQuery 选择器是如何准确地选取您希望应用效果的元素. jQuery 元 ...

  4. hdu 3307 Description has only two Sentences (欧拉函数+快速幂)

    Description has only two SentencesTime Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ...

  5. LLVM example for main

    #include "llvm/IR/CallSite.h" #include "llvm/IR/Instruction.h" #include "ll ...

  6. csdn的app打开贴子显示空白?

    csdn或者虎扑的app打开贴子显示空白,卸载后重装仍然有同样的问题. 可能是android系统的WebView版本太落后. 打开应用市场,更新WebView就可以解决了.

  7. Centos实现回收站机制

    作为一个运维人员,在服务器上删除文件时为了方便经常会直接使用rm *.txt这类通配符,甚至为了省事加-rf参数,如果是确定的话还好,要是在删除的时候一个不留神,那事可就大了. 俗话说常在河边站哪有不 ...

  8. silverlight控件阴影效果示例

    <ScrollViewer MaxHeight="400" VerticalScrollBarVisibility="Auto" HorizontalSc ...

  9. Java浮点数float,bigdecimal和double精确计算的精度误差问题总结

    (转)Java浮点数float,bigdecimal和double精确计算的精度误差问题总结 1.float整数计算误差 案例:会员积分字段采用float类型,导致计算会员积分时,7位整数的数据计算结 ...

  10. FormatMessage与GetLastError配合使用,排查windows api调用过程中的错误

    前一段时间在学习windows api调用过程中,遇到过一些调用错误或者程序没能显示预期的结果,或者直接出现vc运行时错误. 这对新手来说是司空见惯的事,因为不太熟悉难免会出错,出错的信息如果能显示很 ...