等待期待的真相:wait-for-expect - 整合测试的新神器
2024-05-23 22:21:35作者:侯霆垣
在集成和端到端测试中,我们经常面临一个问题:如何优雅地等待某个预期条件变为真?wait-for-expect 是一个解决此类问题的开源库,它让这一切变得简单且高效。
项目介绍
wait-for-expect 是一个用于测试的实用工具,它可以让你在异步操作(如调用外部API、数据库操作或GraphQL订阅)完成并满足预期条件后再进行断言。这个库的核心是基于Jest的期望API,通过智能地重复检查,确保你的测试在规定时间内正确执行。
项目技术分析
wait-for-expect 的工作原理是接收一个函数作为参数,该函数包含了你的expect断言。它会立即检查断言是否为真,如果不是,则会在接下来的每个“tick”里每隔50毫秒再次尝试,直到达到默认的4.5秒超时限制。如果在整个超时期间都未满足条件,它会像你的测试运行器一样最后一次执行断言,这样就能得到熟悉的错误堆栈信息。
从版本0.6.0开始,wait-for-expect 支持Promise,这意味着你可以轻松处理异步操作,例如等待某个数据库查询结果。
应用场景
- 集成测试:在React等框架中,当你模拟fetch请求并希望组件在数据加载完成后更新状态时。
- API调用测试:等待网络请求返回并验证响应。
- 数据库操作测试:在数据库操作完成后验证数据是否正确写入或读取。
- 事件驱动测试:例如,针对WebSocket连接的实时消息推送。
项目特点
- 简洁API:只需要一行代码即可实现等待期望。
- 灵活配置:可自定义超时时间和检查间隔。
- 兼容性好:与Jest和其他测试框架配合良好,支持Promise和async/await。
- 错误反馈清晰:当期望失败时,提供详细错误信息,便于调试。
以下是一个简单的示例,演示了如何使用wait-for-expect 来等待一个数字的变化:
test("它等待数字变化", async () => {
let numberToChange = 10;
setTimeout(() => {
numberToChange = 100;
}, Math.floor(Math.random() * 300));
await waitForExpect(() => {
expect(numberToChange).toEqual(100);
});
});
现在,是时候将wait-for-expect 添加到你的测试工具箱,提升你的测试效率和质量了。只需一小段代码,即可消除那些困扰你的延时和不确定性,让测试变得可靠而流畅。立即尝试,看看它如何改变你的测试体验!
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0214
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
469
465
暂无描述
Dockerfile
778
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
877
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677