首页
学习
活动
专区
圈层
工具
发布

使用Jest测试原生TypeScript项目

webpack.config 自动编译ts+css tsconfig.config ts的配置文件 tslint.json tslint的配置文件 jest.config 配置jest .babelrc...通过官网的Getting started 我们可以在最下方找到 ts-jest 不难理解,我们需要配的其实就是jest加载到什么样类型的文件,使用什么预处理来处理文件。...如果是js文件我通过babel-jest处理,css则使用jest-css-modules。假如没有这些配置,那import了你的库,库里有引入了高特性的js文件,或者css文件就会编译报错。...我选择了jest,jest本身是fb出的,对于react非常友好。本身也做了许多环境上的封装切换jsdom环境或者node环境非常方便。我最后选择了这个。...重新修复了问题后,就可以正常运行工作了。 由于本文不是重点介绍CI,这里就不过多展开了,有兴趣的朋友可以自己摸索下。 总结 至此,你应该对前端UI测试应该大致有一个宏观的了解。

3.5K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用jest进行单元测试

    不扯犊子直接说吧,第一点,用数据、用茫茫多的测试用例去告诉使用者,你的程序是多么鲁棒健壮;第二点,把它作为一种素养去培养吧,当你按照一系列规范去做事,那么你做出来的东西,我想是有品质在的。...jest的安装 在确保你的电脑装有node环境的情况下,我们通过mkdir jest-study && npm init -y来初始化项目,然后我们通过cd jest-study进入到这个目录。...通用写法 "test": "jest" : 这个比较傻瓜式,当执行npm run test这条命令是会去对test目录下的所有文件进行相应的jest测试。..."test:help": "jest --help": 顾名思义,如果你不想全局安装jest,又想看看到底有哪些cli命令的话,就它了。..."test:init": "jest --init": 执行这句就是在根目录创建一个jest.config.js文件,它在创建的时候有很多选择项给你的。

    4.6K60

    如何使用 TSX 在 Node.js 中本地运行 TypeScript

    虽然像Deno这样的运行时能够原生地运行TypeScript的想法令人着迷,不需要编译过程,但在Node中原生运行TypeScript仍然有一定的距离。...但我们可以在Node.js中直接运行TypeScript文件而无需任何编译步骤,这称为加载器(Loaders)。...这两个软件包都是加载器,它们接收运行时加载的文件,并对其执行操作,在我们的情况下,操作是将TypeScript文件编译为JavaScript。...最有趣的部分是,TSX被开发为Node的完整替代品,因此您实际上可以将TSX用作TypeScript REPL,只需使用npm i -g tsx全局安装它,在终端中运行tsx,然后就可以原生地编写TSX...但更酷的是,您可以在运行文件时使用--loader tsx为所有TypeScript文件加载TSX。

    5.8K10

    使用 Jest 进行前端单元测试

    Jest 默认使用 Jasmine 语法,支持直接使用 Promise 和 async/await 进行异步测试,支持对 React 组件进行快照监控, 扩展和集成 Babel 等常用工具集也很方便。...Mock Jest 自带一个 mock 系统,并支持自动和手动 mock。 通常项目中,要测试的文件可能带有很多调用依赖,另外单元测试环境和真实环境可也能存在差异,使得脱离真实环境不能直接运行。...例如下面这段典型的前端业务代码,涉及到网络请求、DOM操作等多个步骤,不在浏览器环境中是无法直接执行。 ....例如使用 jest.useFakeTimers() 把遇到的计时器挂起,在必要时再使用 jest.runOnlyPendingTimers() 执行掉已经挂起的计时器。...另外如果修改了组件代码,需要更新快照,则带上参数 -u 重新运行一次即可,快照就会更新。 详细的解释和说明建议阅读作者的这篇文章 [附2]。

    6.7K90

    实现TypeScript运行时类型检查

    }`);由于JSON.parser返回类型为any, 故在我们需要显示地声明user变量为User类型.但是如果JSON 数据为:{ "gender": 2}这个时候我们的parse 代码还是会成功运行..., 但这个时候如果程序中我们还是按照类型声明那样将gender字段当做0 | 1的枚举, 那么便有可能导致严重的业务逻辑缺陷.根本原因在于, TypeScript 不会对数据的类型进行运行时的检验, TypeScript...的类型一一对应的, 完备程度甚至可以称为TypeScript 的运行时类型检查.io-ts 使用的是组合子(combinator)作为抽象模型, 这与大部分validator generator有本质上的区别...中, 我们也是经常使用"组合" 的方式组合类型:type Union = A | B;type Intersect = A & B;在这个例子中, 我们使用 | 和 & 作为组合子, 将类型A和B组合成新的类型...(ADT)等, 覆盖面之广, 是仅仅一篇博客无法讲完的.有兴趣的读者推荐这篇教程.

    3.1K30

    在 ts + Jest 单元测试中 debugging

    温馨提示:因微信中外链都无法点击,请通过文末的 “阅读原文” 到技术博客中完整查阅版; 本文简要介绍了如何在 Jest 单元测试中利用 Chrome Node DevTools 来辅助调试 1、背景 代码是...Jest运行测试用例的特点是多进程并发运行不同测试案例,达到快速的效果。但是这样对调试来说是没法进行的。这个参数保证了使用一个进程运行所有代码。 接下来就可以开心的 debug 了: ?...全部测试文件 和 debug 单个测试文件 这两种场景,足够了 Debugging TypeScript Jest Tests With Visual Studio Code:文中给出针对 ts +...jest 的 launch.json 的配置项,可以借鉴一下 使用jest+enzyme进行react项目测试 - debug篇:虽说是 2017 年的文章,仍旧有可借鉴性 Debugging with...TypeScript, Jest, ts-jest and Visual Studio Code:对新手友好的单元测试 debugger 入门文章,一步步教你;

    4.8K30

    写代码无BUG,网易云前端单元测试方案总结

    虽然目前很多新版浏览器都支持 了,支持在浏览器中直接运行 ES6 代码,但是浏览器不支持 node_modules ,所以我们的原始 ES6 代码在浏览器上依然无法运行...TypeScript后就不需要使用 babel 来转换了。...如果原始代码已经是 CJS了,可以使用 browserify 来支持浏览器端运行,基本零配置,但是往往现实世界比较复杂,我们有 ES6,JSX 以及 TypeScript 要处理,所以这里我们使用 webpack...虽然 Jest 提供了很丰富的功能,但是并没有内置 ES6 支持,所以依然需要根据不同运行时对代码进行转换,由于 Jest 主要运行在 Node 中,所以需要使用 babel-jest 将 ES Module...shallow 渲染因为不会创建真实 DOM,所以组件中使用 refs 的地方都无法正常获取,如果确实需要使用 refs , 则必须使用 mount。

    11.4K20

    Jest 开箱即用 -VS- Mocha 高度定制

    • TypeScript 支持:Jest 通过 ts-jest 可以无缝集成 TypeScript,配置简单;Mocha 需要针对 TypeScript 进行额外配置,稍微麻烦一点。...• TypeScript 支持: 通过 ts-jest 或 Babel 与 TypeScript 无缝协作。...现在很多项目都用 TypeScript,这个支持很重要 Mocha 简介 Mocha 是一个开源的 JavaScript 测试框架,主要运行于 Node.js,也可配置在浏览器中使用,适合客户端和服务器端的测试...它可能无法完全兼容所有严重依赖 ESM 的现代 JavaScript 项目。如果你的项目大量使用 ES6 模块,可能会遇到一些兼容性问题。...如果你要做 React 组件测试,Jest 会更合适,Mocha 在这方面支持不够完善。 • 没有内置监视模式: Mocha 缺乏 Jest 的高效监视模式,无法在文件更改时重新运行测试。

    9910
    领券