mocha-only和skip的用法

测试用例的管理

only方法

大型项目有很多测试用例。有时,我们希望只运行其中的几个,这时可以用only方法。describe块和it块都允许调用only方法,表示只运行某个测试套件或测试用例。

下面写一个案例,结构如下,index.test.js是index.js的测试文件

mocha-only和skip的用法_第1张图片

 index.js如下

function add(x, y) {
  return x + y;
}

module.exports = add;

index.test.js如下

var index = require("./index.js");
var expect = require("chai").expect;
// describe叫做测试套件
describe.only("加法函数的测试", function() {
  it("1 加 1 应该等于 2", function() {
    expect(index(1, 1)).to.be.equal(2);
  });

  it("任何数加0应该等于自身", function() {
    expect(index(1, 0)).to.be.equal(1);
  });
});
describe("测试", function() {
  // it叫做测试用例
  it.skip("1加1应该等于2", function() {
    //断言
    expect(index(1, 1)).to.be.equal(2);
  });

  // 异步测试
  it("测试应该2000毫秒后结束", function(done) {
    var x = false;
    var f = function() {
      x = true;
      expect(x).to.be.ok;
      done(); // 通知Mocha测试结束
    };
    setTimeout(f, 1000);
  });

  // 异步请求
  // it("异步请求应该返回一个对象", function(done) {
  //   request.get("https://api.github.com").end(function(err, res) {
  //     expect(res).to.be.an("object");
  //     done();
  //   });
  // });

  // it("异步请求应该返回一个对象", function() {
  //   return fetch("https://api.github.com")
  //     .then(function(res) {
  //       return res.json();
  //     })
  //     .then(function(json) {
  //       expect(json).to.be.an("object");
  //     });
  // });
});


一个describe表示一个区块,在加法函数的测试这个区块中加了一个参数.only,所以只会执行本区块

结果如下

mocha-only和skip的用法_第2张图片

 同样,也可以给it(测试用例前面加参数),就只会执行当前的测试用例

结果如下

mocha-only和skip的用法_第3张图片

skip方法

表示跳过指定的测试套件或测试用例。用法同only

mocha-only和skip的用法_第4张图片

mocha-only和skip的用法_第5张图片

 

你可能感兴趣的:(mocha-only和skip的用法)