首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

异步函数中的异常处理及测试方法

你将学到什么 通过后面的内容你将学到: 如何从 Javascript 的异步函数中抛出错误 如何使用 Jest 测试来自异步函数的异常 要求 要继续往下读你应该: 对 Javascript 和 ES6...有基本的了解 安装 Node.Js 和 Jest 如何从 Javascript 的常规函数中抛出错误 使用异常而不是返回码(清洁代码)。...这是对它的测试(使用Jest): ? 也可以从 ES6 的类中抛出错误。在 Javascript 中编写类时,我总会在构造函数中输入意外值。下面是一个例子: ? 以下是该类的测试: ?...以下是在Jest中测试异常的规则: 使用 assert.throws 来测试普通函数和方法中的异常 使用 expect + rejects 来测试异步函数和异步方法中的异常 如果你对如何使用 Jest...测试 Koa 2 感兴趣,请查看使用Jest和Supertest进行测试的简绍这篇文章。

3K30

React Native自动化测试

我们期待你能帮助我们提高测试覆盖率,以及提供更多的测试代码或是测试用例。 使用Jest来测试 Jest是在命令行通过node来执行的纯js测试工具。测试代码放置在__tests__目录下。...你可以在react-native源代码的根目录中使用如下命令来运行现有的jest测试代码: npm test 我们建议你在贡献代码的时候也添加自己的测试代码。...测试代码需要以JS写成的,并且必须在测试完成后调用TestModule.markTestCompleted()方法,否则测试过程会超时并且失败。失败的表现一般是抛出一个JS异常。...测试错误条件也是可行的,使用runTest:module:initialProps:expectErrorRegex:或是runTest:module:initialProps:expectErrorBlock...:方法,它们会按提供的条件去验证抛出的错误是否符合。

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

    如何做前端单元测试

    另外,报告显示超 80% 人认为单元测试可以有效的提高质量,超 60% 人使用过 Jest 去编写前端单元测试,超 40% 的人认为单元测试覆盖率是重要的且覆盖率应该大于 80%。...常见单元测试工具 目前用的最多的前端单元测试框架主要有 Mocha (https://mochajs.cn/)、Jest (https://www.jestjs.cn/),但我推荐你使用 Jest,因为...都有很大的优势,因此推荐你使用开箱即用的 Jest 如何开始?...但是需要注意的是:我们必须使用一个函数将被测试的函数做一个包装,正如下面 getIntArrayWrapFn 所做的那样,否则会因为函数抛出错误导致该断言失败。.../src/utils/getIntArray'; test('getIntArray(3.3)应该抛出错误', () => { function getIntArrayWrapFn() {

    3.3K20

    从echarts-for-react源码中学习如何写单元测试

    /src/utils'; // 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 jest.useFakeTimers(); // 描述块,将多个...() 作用: 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 这里使用jest.useFakeTimers()的目的就是暂停正在执行的timer...而影响到「测试目标」,为了减少依赖,就使用了 mock function 即 jest.fn() // 参考:https://medium.com/enjoy-life-enjoy-coding.../>); // 注销组件 component.unmount(); expect(() => { // 组件注销后是获取不到实例的,所以判断是 toThrow() 抛出错误...); }).toThrow(); }); 通过component.unmount()卸载组件后,再去获取组件的instance,这时候肯定是获取不到,会报错的,所以通过toThrow()来抛出错误

    6.2K50

    对 React 组件进行单元测试

    断言(assertions) 断言是单元测试框架中核心的部分,断言失败会导致测试不通过,或报告错误信息。...React 单元测试中用到的工具 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架 -- Jest的使用更简单,并且提供了更高的集成度、更丰富的功能...四个基础单词 编写单元测试的语法通常非常简单;对于jest来说,由于其内部使用了 Jasmine 2 来进行测试,故其用例语法与 Jasmine 相同。...实际使用中,适当的自定义配置一下,会得到更适合我们的测试场景: //jest.config.jsmodule.exports = { modulePaths: [ "Jest 本身也有一些实现 spy 等的手段,但 sinon 使用起来更加方便。 III.

    4.3K40

    web前端好帮手 - Jest单元测试工具

    本文介绍如何使用Jest覆盖Web前端单元测试、如何统计测试覆盖率,Jest对比Mocha等内容。 Jest是什么? ? Jest是一个令人愉快的 JavaScript 测试框架,专注于简洁明快。...“错误抛出”: // 假设urlParse函数对参数校验非法报错function fetchUserInfo(uid) { if (!...test('必要参数uid漏传报错', () => { expect(fetchUserInfo()).toThrow(); }); 注意测试错误抛出时,要在测试逻辑外加一层函数包裹,Jest才能捕获到错误.../test.txt"); expect(data.toString()).toBe("333"); }); 注意,Jest检测到异步测试时(比如使用了done或者函数返回promise),Jest会等待测试完成.../ 在group-B作用域下,仅对group-B下测试用例生效 beforeEach(() => {}) }); }); 以上Jest的基础使用介绍,足够应付大部分的场景,下面将针对Jest

    5K40

    Jest测试语法系列之Matchers

    关于Jest测试的基础内容,可以参考之前的博客:前端单元测试之Jest 本文主要讲的是匹配器(Matchers),匹配器(Matchers)是Jest中非常重要的一个概念,它可以提供很多种方式来让你去验证你所测试的返回值...后面的 toBe 就是一个matcher,当Jest运行的时候它会记录所有失败的matcher的详细信息并且输出给用户,让维护者清楚的知道failed的原因,如果我们改成 toBe(5),将会输出错误的提示...,如下图: toBe 是测试具体的某一个值,如果需要测试对象,需要用到toEqual。...,有时需要区分undefined、null和false,这些可以使用Jest的真实性匹配。...function是否会抛出特定的异常信息,可以用 toThrow 。

    55020

    浅谈前端测试

    这里不赘述 node 环境   推荐测试框架 jest   jest 是 FB 的杰作之一,方便各种场景的 js 代码测试,这里选择 jest 是因为确实方便   使用方法及配置信息可以去官方文档   ...text)  }  module.exports = getFile   这时我们并不需要关心 text.txt 是否真的存在,也不需要关系 text 的内容具体是什么,我们的关注点应该在于读取文件错误时能否及时抛出异常...,注意的就是对一个 jest.fn() 多次进行修改会导致测试用例之间的相互影响,这里尽量使用 Once 结尾方法,复杂场景可以如下 beforeEach(() => {  mocks.fs.readFileSync.mockReset...()  })   每次执行 test 前先清除 mock,避免多个测试用例之间复杂化 mock 导致错误   小结:单元测试中的 mock 是个测试思路,我们无需关心外部文件和依赖是什么,只要能模拟出正确的情况程序是否按规则执行...,错误的情况程序是否有异常处理,逻辑是否正确等。

    1.7K10

    vue中关于测试的介绍

    断言库 所谓“断言” ,就是判断源码的实际执行结果与预期结果是否-致,如果不一致就抛出一个错误。下面这句断言的意思是,调用add(1, 1) ,结果应该等于2....with at of same Jest (一般使用这个,请仔细阅读) 官方提供的单元测试的模块@vue/test-utils,它使用的是Jest风格的expect断言,具体示例如下: // 挂载这个组件...const wrapper = shallowMount(MyComponent) // 这里是一些 Jest 的测试,你也可以使用你喜欢的任何断言库或测试 describe('MyComponent...一个组件一般就对应一个测试文件,文件后以为spec.js结尾 目录结构如下: 3. jest使用api,可参考官方文件https://vue-test-utils.vuejs.org/api/...写好后,使用npm run unit指令运行,进行测试 最后,本文关于vue中的测试介绍,就到这。还有不清楚的,可以本文留言,一起讨论

    98610

    万字详文:彻底搞懂 Jest 单元测试框架

    expect 是一个断言,该语句使用输入 1 和 2 调用被测函数中的 sum 方法,并期望输出 3。 toBe 是一个匹配器,用于检查期望值,如果不符合预期结果则应该抛出异常。...}; 如何实现断言和匹配器 断言库也实现也很简单,只需要封装一个函数暴露匹配器方法满足以下公式即可: expect(A).toBe(B) 这里我们实现 toBe 这个常用的方法,当结果和预期不相等,抛出错误即可...try/catch 捕获错误,并打印堆栈信息方面定位问题。...而 jest.fn 的实现也不难,这里我们使用一个闭包 mockFn 把替换的函数和参数给存起来,方便后续测试检查和统计调用数据。...,我们并不需要手动引入 test、expect 和 jest 这些函数,每个测试文件可以直接使用,所以我们这里需要创造一个注入这些方法的运行环境。

    7.9K20

    对 Vue-Router 进行单元测试

    可以在 测试中使用一个相同的 localVue,并将其声明在第一个 describe 块之外。而由于要为不同的路由做不同的测试,所以把 router 定义在 it 块里。...为使用了 mount 的大型渲染树做些变通 使用 mount 在某些情况下很好,但有时却是不理想的。...使用了下面的写法后,以上测试也将能通过: jest.mock("@/components/NestedRoute.vue", () => ({ name: "NestedRoute", render...在组件中声明 要确保这些运作正常,一般是集成测试的工作,因为需要一个使用者从一个理由导航到另一个。但也可以用单元测试检验导航 guards 中调用的函数是否正常工作,并更快的获得潜在错误的反馈。...,你可能想导入 router 实例,并试图通过 router.beforeHooks[0]() 的写法调用 beforeEach;但这将抛出一个关于 next 的错误 -- 因为没法传入正确的参数。

    2.2K10

    在 vue-test-utils 中 mock 全局对象

    renders successfully", () => { const wrapper = shallowMount(Bilingual) }) }) 通过 yarn test:unit 运行测试将抛出一堆错误堆栈...(译注:通过这种方式就不能在单元测试中耦合与特定语言相关的内容了,因为翻译功能实际上已失效,也更无法处理可选参数等) 使用配置设置默认的 mocks 有时需要一个 mock 的默认值,这样就不用为每个测试用例都设置一遍了...,所以我将把默认 mock 描述在 jest.init.js 文件中 -- 该文件会在测试运行前被自动加载。...//jest.init.js import VueTestUtils from "@vue/test-utils" import translations from ".... (译注:依然无法应付复杂的翻译) 总结 本文论述了: 在测试用例中使用 mocks 以 mock 一个全局对象 用 config.mocks 设置默认的 mock

    1.6K10

    掌握JavaScript的异步编程,让你的代码更高效

    1、使用Async/Await进行错误处理 在现代JavaScript开发中,错误处理是一个必不可少的技能,尤其是在进行异步操作时。使用Async/Await可以让你的错误处理变得更加简单和直观。...如果响应不正常,比如返回404或500错误,就会抛出一个错误,并在catch块中进行处理。这不仅让代码更加整洁,也使错误处理逻辑更为集中和清晰。...以下是一些常用的测试框架和技巧: 使用 Jest 进行异步测试 Jest是一个强大的测试框架,支持异步测试和API模拟。...Mocha 进行异步测试 Mocha也是一个流行的测试框架,支持异步测试。...不管是处理用户输入的防抖与节流,还是通过Promise链式处理、重试逻辑与断路器模式来优雅地处理错误,亦或是利用Jest和Mocha进行异步代码的测试,这些方法都能帮助你打造更加健壮、可维护和高性能的JavaScript

    13210

    React 现代化测试

    (代表库: jest、mocha) 集成测试: 模拟用户的行为进行测试, 对网络请求、获取数据库的数据等依赖第三方环境的行为进行 mock。...(代表库: jest、react-testing-library) e2e 测试: 模拟用户在真实环境上操作行为(包括网络请求、获取数据库数据等)的测试。..., 此时在 expect(wrapper.state('index')).toBe(0) 的地方抛出了错误❌, 这就是所谓的测试用例对代码进行了错误否定。...因为这段代码对于使用方来说是不存在问题的, 但是测试用例却抛出错误, 此时开发者不得不做'无用功'来调整测试用例适配新代码。...相较于 enzyme, react-testing-library 所提供的 api 更加贴近用户的使用行为, 使用其对上述测试用例进行重构: import { render, fireEvent }

    93930

    也来扯扯 Vue 单元测试

    单元测试能避免出现一些代码运行结果与预期不符的错误,通常是一些比较低级但又难以发现的问题。 单元测试能够避免在升级更新、修复 BUG 的时候引入一些意料之外的问题。...另外值得注意的是,单元测试并不能完全代替功能测试,因为程序本身设计的逻辑错误或者其它的一些环境因素所造成的影响,单元测试可能无能为力。...而使用 Jest 后,只要安装它,全都搞定了。 全面的官方文档,易于学习和使用 Jest 的官方文档很完善,对着文档很快就能上手。...Jest 甚至提供了 jest-codemods 这一工具,用来将使用其它包的测试迁移为使用 Jest 缺点 jsdom 的一些局限性 因为 Jest 是基于 jsdom 的,jsdom 毕竟不是真实的浏览器环境...周边相关的包可能还不完善 例如 vue-jest,目前的版本并不能完全实现 vue-loader 的功能。比如,使用 sass,postcss 之类的功能,它会抛出警告信息。

    1.8K30

    单元测试

    代码信心的体现 测试可以确保得到预期的结果 作为现有代码行为的描述 促使开发者写可测试的代码,可测试的代码可读性会更高 如果依赖的组件有修改,受影响的组件能在测试中发现错误 测试内容 什么是细节?...,并完成jest相关配置 (目前) 项目中使用jest编写了测试用例 确保项目执行下述jest命令无问题 (生成报告,指定报告位置,生成json数据,指定json数据输出文件) jest --coverage.../BLoginModal/services/wxApi'; // 这种方式设计到代码细节问题需避免使用,如果方法名 getWXSanqrAjax 变更将导致测试用例执行失败 jest.spyOn(wxApis...waitFor的错误使用 用 waitFor 等待 find* 的查询结果 // ❌ const submitButton = await waitFor(() => screen.getByRole...,而且抛出的错误信息会更友好。

    31210
    领券