对TypeScript库进行单元测试的方法
前端  /  管理员 发布于 3年前   397
原文发布于2017年7月,为保证能正常运行,其中部分命令进行了调整。当时TypeScript版本为2.x,但依旧具有借鉴意义。
单元测试能限制你库中Bug的「生长」。随着编写的库越来越大,你不能总是手工测试每个特性。但你可以使用单元测试来测试每个特性,并且编写起来并不难。下面展示如何在Typescript中设置单元测试!
步骤1:安装用于单元测试的包
单元测试assert
(推断)代码中一些属性。例如你有一个方法add(x,y)
,其应该正确地将x
和y
相加,通过单元测试你可以进行如下测试assert(add(3,4)).equals(7)
。
一些用于单元测试的库提供了好用的assert
方法来执行测试。我们这里使用了Mocha和Chai,通过如下命令进行安装:
npm i mocha @types/mocha chai @types/chai ts-node typescript --save-dev
步骤2:编写第一个单元测试
假设你有以下单元:
typescript-library/src/math.ts
export function add(x: number, y: number) { return x + y;}
那对应的单元测试可能是这样的:
typescript-library/src/math.test.ts
import { add } from './math';import * as mocha from 'mocha';import * as chai from 'chai';const expect = chai.expect;describe('My math library', () => { it('should be able to add things correctly' , () => { expect(add(3,4)).to.equal(7); });});
步骤3:运行单元测试
您可以使用以下命令运行测试:
./node_modules/mocha/bin/mocha --reporter spec --require ts-node/register src/**/*.test.ts
然后应该会在控制台中看到一个输出,如下所示:
您可以将这个长命令放入package.json
中转换成"scripts:{"test":"…"}"
然后用npm test运行测试。也就是说此时的package.json
应该是:
{ "devDependencies": { "@types/chai": "^4.1.7", "@types/mocha": "^5.2.7", "chai": "^4.2.0", "ts-node": "^8.3.0", "mocha": "^6.1.4" }, "scripts": { "test": "./node_modules/mocha/bin/mocha --reporter spec --require ts-node/register src/**/*.test.ts" }}
如果您想运行单独的某个单元测试,可以用./node_modules/mocha/bin/mocha --reporter spec --grep "TestName" --require ts-node/register src/**/*.test.ts
。“TestName”可以是任何的describe
值,在本例中就如./node_modules/mocha/bin/mocha --reporter spec --grep "My math library" --require ts-node/register test/**/*.test.ts
。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..博主 在
科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 @ mashrdn 多切换几个节点测试,免费ssr是没那么稳..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号