TypeScript Jest 单元测试 搭建

NPM TypeScript 项目搭建

创建目录

bash 复制代码
mkdir mockproject

cd mockproject

初始化NPM项目

bash 复制代码
npm init -y

安装TypeScript

bash 复制代码
npm i -D typescript

使用VSCode 打开项目

创建TS配置文件tsconfig.json

json 复制代码
{
  "compilerOptions": {
    "target": "es5",
    "module": "commonjs",
    "declaration": true,
    "outDir": "./lib",
    "strict": true,
    "lib": ["es6"]
  },
  "include": ["src"],
  "exclude": ["node_modules"]
}

创建src 目录,创建文件src/index.ts 内容如下:

ts 复制代码
export const Hello = (name: string) => `Hello ${name}`;

在package.json中的scripts中添加ts的构建命令

json 复制代码
"build": "tsc"

CTRL + ` 打开终端测试构建。

bash 复制代码
npm run build

构建完成后可以发现项目目录中多了lib 里面就是我们的Hello函数。

Jest 单元测试集成

安装依赖

bash 复制代码
npm i -D jest ts-jest @jest/globals

安装后package.json中开发依赖将会出现如下:

生成Jest配置文件

bash 复制代码
npx ts-jest config:init

jest.config.js 生成内容如下:

js 复制代码
/** @type {import('ts-jest').JestConfigWithTsJest} **/
module.exports = {
  testEnvironment: "node",
  transform: {
    "^.+.tsx?$": ["ts-jest",{}],
  },
};

在package.json中添加单元测试命令,若原来有test命令则删除,填入一下内容。

json 复制代码
"test": "jest"

通常会建立一个tests目录用于存放测试用例,tests中的测试用名称与被测试对象名称保持一致,但是添加上.test.ts后缀,目录结构也保持一致。

创建测试目录tests,创建测试文件tests/index.test.ts

ts 复制代码
import { describe, expect, test } from '@jest/globals';
import { Hello } from '../src/index';

describe('Mock module', () => {
    test('Hello world', () => {
        expect(Hello("abc")).toBe("Hello abc");
    });
});

打开终端使用测试命令执行测试

bash 复制代码
npm run test

可以看到执行测试后执行我们定义的测试用例,并提示了Pass的提示。

参考文献

1\]. [掘金 . \[译文\]一步步构建发布一个 TypeScript NPM 包 . 小被子 . 2019.07 . https://juejin.cn/post/6844903892119977998](https://juejin.cn/post/6844903892119977998) \[2\]. [jest . Getting Started . 2024 . https://jestjs.io/docs/getting-started](https://jestjs.io/docs/getting-started)

相关推荐
程序员小寒8 小时前
前端性能优化之白屏、卡顿指标和网络环境采集篇
前端·javascript·网络·性能优化
次顶级10 小时前
表单多文件上传和其他参数处理
前端·javascript·html
小一梦10 小时前
宝塔面板单域名部署多个 Vue 项目:从路径冲突到完美共存
服务器·javascript·vue.js
柳杉11 小时前
两款惊艳的 WebGL 开源项目推荐
前端·javascript·数据可视化
jingxindeyi11 小时前
react实现狼吃羊游戏
javascript·react.js·游戏
小金鱼Y12 小时前
别再乱拷贝了!JS 浅拷贝 vs 深拷贝全解析
前端·javascript
steel808812 小时前
Spring Boot 整合 log4j2 日志配置教程
spring boot·单元测试·log4j
英俊潇洒美少年13 小时前
React19 useActionState的注意事项
前端·javascript·react.js
发现一只大呆瓜13 小时前
性能优化:CDN 缓存加速与调度原理
前端·javascript·面试