• 框架选择
    • 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. spring 异常记录

    1.异常: java.lang.IllegalArgumentException: No converter found for return value of type: class java.ut ...

  2. jdk环境变量的配置并检测是否配置成功

    JDK环境变量配置进行java开发,首先安装JDK,安装后进行环境变量配置1,下载JDK(http://java.sun.com/javase/downloads/index.jsp)2.安装jdk- ...

  3. html之如何让文字两端对齐

    text-align: justify;/*英文*/ text-align-last: justify;/*中英文*/ text-align-last: justify;亲测有效(chrome)

  4. C#字符串操作(參照圓友)

    直接上實例代碼 staticvoid Main(string[] args) { string s =""; //(1)字符访问(下标访问s[i]) s ="ABCD&q ...

  5. jqGrid的选中行事件

    http://blog.csdn.net/u014381863/article/details/50375121  

  6. 利用googleapis在日文系统中改善中文字

    加入以下两句 1. <head> <link rel="stylesheet" href="http://fonts.googleapis.com/ea ...

  7. php_access_ADOConn 备忘

    1.咕~~(╯﹏╰)b 各种乱码. 2.本来是MFC+Access 用msado15.dll写的系统,闲的想用php改改. Demo.php <meta http-equiv="Con ...

  8. Oracle 分页原理

    oracle rownum 及分页处理的使用方法 在实际应用中我们经常碰到这样的问题,比如一张表比较大,我们只要其中的查看其中的前几条数据,或者对分页处理数据.在这些情况下我们都需要用到rownum. ...

  9. SQLserver聚集表、堆和索引

    SQL Server 表使用下列两种方法之一来组织其分区中的数据页: 聚集表是有聚集索引的表.数据行基于聚集索引键按顺序存储.聚集索引按 B 树索引结构实现,B 树索引结构支持基于聚集索引键值对行进行 ...

  10. 修复IE9.0下PlaceHolder 属性问题js脚本

    在开发前端系统时候碰到这种兼容问题,以下是个人解决方案,希望能给其他人带来帮助: var JPlaceHolder = { //检测 _check: function () { return 'pla ...