随着js 愈来愈强大,平常使用中关于js 的问题也就越突出了,咱们须要关注的点也就不能只像之前那样
只编写简单的功能实现,咱们同时也须要关注js 的健壮性,测试就是其中一个比较重要的环节,如下
是ava 测试框架的一个简单使用,关于ava 的介绍能够查看官方文档git
demo 同时集成了简单的github repo 测试github
为了测试,代码使用了typescript,经过tsc 实时编译typescript
├── libs
│ ├── app.d.ts
│ └── app.js
├── package.json
├── src
│ └── app.ts
├── tests
│ └── app.js
├── tsconfig.json
{
"name": "@rongfengliang/ava-test-learning",
"version": "1.0.0",
"main": "index.js",
"license": "MIT",
"devDependencies": {
"ava": "^2.4.0",
"typescript": "^3.6.4",
"zen-observable": "^0.8.14"
},
"scripts": {
"test:live": "ava -v -w",
"test": "ava",
"build:live": "tsc --watch"
},
"publishConfig": {
"registry": "https://npm.pkg.github.com/"
}
}
src/app.ts 待测试的代码npm
// define user entity
let user = {
/** user name */
name:"dalong",
/** user age */
age:33
}
// for export default
export default {
user
}
export {
user
}
tests/app.jsjson
import test from 'ava';
import Observable from "zen-observable"
import {user} from "../libs/app"
test('foo', t => {
t.plan(3)
let name = "dalong"
t.log(`input name ${name}`)
return Observable.of(1, 2, 3, 4, 5, 6)
.filter(n => {
return n % 2 === 0;
})
.map(() => t.pass());
});
test.todo('will think about writing this later');
test('bar', async t => {
const bar = Promise.resolve('bar');
t.is(await bar, 'bar');
});
test('username', t => {
t.log("test for username is equal",test.meta.file)
t.is(user.name,"dalong")
});
yarn build:live
yarn test:live
npm login --registry=https://npm.pkg.github.com
注意输入的信息,用户密码使用生成的我的token,同时注意token 须要包含操做package 的权限,同时注意项目中pacakge.json
中的名字,当前github 支持的repo 是scope 类型的app
npm publish
以上是一个简单的测试,实际上ava 功能很强大,同时官方提供的文档也比较详细,咱们能够结合nyc 提供覆盖率的处理框架
https://github.com/rongfengliang/ava-test-learning
https://github.com/avajs/avaasync