您的位置:首页 > 汽车 > 新车 > 深圳龙江网站设计_房屋设计软件有哪些_北京网络营销推广外包_安卓aso优化

深圳龙江网站设计_房屋设计软件有哪些_北京网络营销推广外包_安卓aso优化

2025/2/27 12:22:43 来源:https://blog.csdn.net/q1009020096/article/details/145061893  浏览:    关键词:深圳龙江网站设计_房屋设计软件有哪些_北京网络营销推广外包_安卓aso优化
深圳龙江网站设计_房屋设计软件有哪些_北京网络营销推广外包_安卓aso优化

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com