当前位置: 首页 > news >正文

TypeScript Jest 单元测试 搭建

NPM TypeScript 项目搭建

创建目录

mkdir mockprojectcd mockproject

初始化NPM项目

npm init -y

在这里插入图片描述

安装TypeScript

npm i -D typescript

在这里插入图片描述

使用VSCode 打开项目

在这里插入图片描述
创建TS配置文件tsconfig.json

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

在这里插入图片描述

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

export const Hello = (name: string) => `Hello ${name}`;

在这里插入图片描述

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

"build": "tsc"

在这里插入图片描述

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

npm run build

在这里插入图片描述

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

Jest 单元测试集成

安装依赖

npm i -D jest ts-jest @jest/globals

在这里插入图片描述
安装后package.json中开发依赖将会出现如下:
在这里插入图片描述
生成Jest配置文件

npx ts-jest config:init

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

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

在这里插入图片描述

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

"test": "jest"

在这里插入图片描述

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

创建测试目录tests,创建测试文件tests/index.test.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");});
});

在这里插入图片描述

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

npm run test

可以看到执行测试后执行我们定义的测试用例,并提示了Pass的提示。
在这里插入图片描述

参考文献

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

http://www.lryc.cn/news/519875.html

相关文章:

  • 基于 SSH 的任务调度系统
  • filestream安装使用全套+filebeat的模块用法
  • java项目之房屋租赁系统源码(springboot+mysql+vue)
  • sap mm学习笔记
  • 代码随想录_链表
  • EF Code 并发控制
  • ceph fs status 输出详解
  • FFmpeg Muxer HLS
  • 如何用SQL语句来查询表或索引的行存/列存存储方式|OceanBase 用户问题集锦
  • 回归预测 | MATLAB实GRU多输入单输出回归预测
  • 【OpenGL/Assimp】渲染模型、半透明材质与封装光源
  • pandas与sql对应关系【帮助sql使用者快速上手pandas】
  • Linux WEB漏洞
  • 音视频入门基础:RTP专题(2)——使用FFmpeg命令生成RTP流
  • 大语言模型预训练、微调、RLHF
  • vue3后台系统动态路由实现
  • 解决idea中无法拖动tab标签页的问题
  • WMS仓库管理系统,Vue前端开发,Java后端技术源码(源码学习)
  • 25/1/12 嵌入式笔记 学习esp32
  • 【NLP】ELMO、GPT、BERT、BART模型解读及对比分析
  • go语言学习(数组,切片,字符串)
  • PM 实战 - 智能药盒PRD + 市场规模分析
  • SQL刷题快速入门(二)
  • hive迁移后修复分区慢,怎么办?
  • 代码随想录算法训练营day27
  • python 代码使用 DeepXDE 库实现了一个求解二维非线性偏微分方程(PDE)的功能
  • 【Go】:深入解析 Go 1.24:新特性、改进与最佳实践
  • VUE3 一些常用的 npm 和 cnpm 命令,涵盖了修改源、清理缓存、修改 SSL 协议设置等内容。
  • 【SpringBoot】@Value 没有注入预期的值
  • 【STM32-学习笔记-6-】DMA