美文网首页
JS单元测试

JS单元测试

作者: 机智的老刘明同志 | 来源:发表于2020-01-06 14:41 被阅读0次

1.基本概念:

1.1单元测试:

        单元测试是指对软件中的最小可测试单元在与程序其他部分相隔离的情况下进行检查和验证的工作,这里的最小可测试单元通常是指函数或者类

1.2js中的单元测试

        js 单元测试常见组合是 mocha + chai(chai-spies,chai-as-promised)

        mocha是 js 的一个单元测试框架,既可以在浏览器环境下运行,也可以在Node.js环境下运行。

        chai 则是一个断言库

1.3什么是Mock,Stub,Spy?

        spy:监视函数的被调用情况

        stub:拥有spy的全部功能,但是会彻底取代这个函数

        mock:定义一个对象的具体期待,然后验证期待是否和测试数据一致。

2.mocha:

2.1安装与部署

    1.全局或项目安装依赖

            npm install -g mocha    /     npm install --save-dev mocha

    2.package.json中加入脚本

    3.定义目录结构,编写测试代码

        准备我们要测试的addNum()

这是我们要测试的addNum()

        mocha会自动运行test目录下的所有文件(不包括test的子目录)

这是测试脚本

        得到执行结果

2.2语法

    1.普通的同步测试

        describe:测试套件,表示一组相关的测试。arg1:测试套件名称(例如测试index.js),arg2:执行的函数

        context:describe的别名

        it:测试用例,表示一个独单的测试。arg1:测试用例的名称(例如两个数字相加之和),arg2:执行的函数

        specify:it的别名

    2.异步测试

book.read

        手动调用done()表示测试成功可以结束,done(err)表示测试出错。

    3. 钩子

3.chai

3.1chai

        chai是一种断言库, 它的expect和should都是BDD风格(行为驱动开发)的。这里推荐使用expect。 

        chai的语法更近似于代码,例如上面addNum()的测试用例则更具备语义性:

        期望(expect) 函数addNum(1,2)的结果等于4。

3.2常用语法

        chai有很多没有任何作用,只是为了提高语义性的"助词"

        例如:to,be,been,is,that,which,and,has,have,with,at,of,same

        .equal(value )    

        断言目标严格等于(===)value 

        .include(value)

        判断数组、字符串是否包含某值

        .deep

        配合equal和property使用。深度递归比较对象的键值对

        .property(name, [value])

        断言目标是否拥有某个名为name的属性

        .throw()

        断言目标函数会抛出一个指定错误或错误类型

        .instanceof(constructor)

        断言目标是构造函数constructor的一个实例

4.chai-spies + chai-as-promised

4.1简介

        chai-spies      使chai支持了spy功能

        chai-as-promised    使chai可以支持到Promise

4.2demo        

        引入依赖

        这里注意,当我们使用了chai.spy.on之后,原来index.addNum已经被我们从 x+y 替换成了 x*y

4.3实际应用

        比如说我们本地测试需要调用小程序云端DB就可以使用spy.on 

相关文章

  • Node.js 中的单元测试

    《深入浅出 Node.js》阅读随笔 Node.js 中的单元测试与通常后端语言中单元测试大致相同,主要包含断言、...

  • chai.js单元测试

    chai.js 单元测试 BDD/TDD assert库 chai.js有三种语法,我们使用expect,常用写法...

  • 单元测试框架:Jest

    Jestfacebook推出的js单元测试的语言1.首先需要在项目文档中安装jest包2.创建需要进行单元测试的源...

  • QUnit入门

    标签: 前端开发 1. QUnit是什么? 一个js进行单元测试的库单元测试就是检验代码是否按预期运作。代码写的测...

  • JS单元测试

    1.基本概念: 1.1单元测试: 单元测试是指对软件中的最小可测试单元在与程序其他部分相隔离的情况下进行检查和验证...

  • jasmine

    用jasmine做js单元测试。 安装 安装jasmine 安装jasmine reporter 总命令: 初始化...

  • Node.js笔记六:单元测试

    Node.js笔记六:单元测试 源码github地址在此,记得点星:https://github.com/bran...

  • 单元测试基本配置

    兼容es6的mocha单元测试项目配置 笔记 test/xx.js中,describe, it中function使...

  • Mocha JS单元测试 覆盖率

    Mocha JS单元测试 覆盖率 简单使用步骤 项目基于npm 安装 nyc npm i nyc --save-d...

  • 使用webpack+babel编译打包一个自己的js库

    使用webpack4 + babel7来生成自己的js库,同时加入eslint校验,jsdoc生成,单元测试。 需...

网友评论

      本文标题:JS单元测试

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