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

前端测试吐槽:别再写那些没用的测试了!

前端测试吐槽别再写那些没用的测试了毒舌时刻前端测试就像体检——每个人都知道要做但真正认真做的没几个。Jest、React Testing Library、Cypress... 一堆测试工具让你挑花了眼结果你的测试还是写得像一坨屎。我就想不明白了为什么测试要写得这么复杂你看看现在的测试代码mock、stub、spy一堆概念把人搞晕。还有那些测试用例写得比业务代码还长维护起来比登天还难。别跟我提什么测试覆盖率先把你的测试用例写得有意义点再说。还有那些为了测试而测试的什么都要测试结果测试代码比业务代码还多你说这能不浪费时间吗为什么你需要这个保证代码质量好的测试能帮助你发现bug确保代码质量。提高开发效率测试能帮助你快速定位问题减少调试时间。便于重构有了测试你可以放心地重构代码不用担心破坏现有功能。面试必备面试官最喜欢问测试的问题掌握这些能让你面试更有底气。装X神器跟同事聊起来你能说上几句测试的技巧瞬间提升逼格。反面教材// 1. 测试过度 // component.test.js import { render, screen } from testing-library/react; import Component from ./Component; describe(Component, () { test(renders correctly, () { render(Component /); expect(screen.getByText(Hello)).toBeInTheDocument(); }); test(renders with props, () { render(Component nameJohn /); expect(screen.getByText(Hello John)).toBeInTheDocument(); }); test(renders with different props, () { render(Component nameJane /); expect(screen.getByText(Hello Jane)).toBeInTheDocument(); }); // 一堆重复的测试用例 }); // 问题测试过度重复测试相同的功能 // 2. 测试依赖外部环境 // api.test.js import axios from axios; import { fetchData } from ./api; describe(fetchData, () { test(fetches data successfully, async () { const data await fetchData(); expect(data).toBeDefined(); expect(data.length).toBeGreaterThan(0); }); }); // 问题测试依赖外部API不稳定 // 3. 测试实现细节 // component.test.js import { render } from testing-library/react; import Component from ./Component; describe(Component, () { test(has correct class name, () { const { container } render(Component /); expect(container.firstChild).toHaveClass(component); }); test(renders button with correct text, () { const { container } render(Component /); const button container.querySelector(button); expect(button.textContent).toBe(Click me); }); }); // 问题测试实现细节容易被破坏 // 4. 测试代码质量差 // component.test.js import { render, fireEvent } from testing-library/react; import Component from ./Component; describe(Component, () { test(button click works, () { const { getByText } render(Component /); const button getByText(Click me); fireEvent.click(button); // 没有断言测试永远通过 }); }); // 问题测试没有断言无法验证功能问题测试过度重复测试相同的功能测试依赖外部环境不稳定测试实现细节容易被破坏测试代码质量差没有断言正确的做法前端测试指南// 1. 合理的测试用例 // component.test.js import { render, screen } from testing-library/react; import Component from ./Component; describe(Component, () { test(renders correctly with default props, () { render(Component /); expect(screen.getByText(Hello)).toBeInTheDocument(); }); test(renders correctly with custom name, () { render(Component nameJohn /); expect(screen.getByText(Hello John)).toBeInTheDocument(); }); }); // 2. 模拟外部依赖 // api.test.js import axios from axios; import { fetchData } from ./api; jest.mock(axios); describe(fetchData, () { test(fetches data successfully, async () { const mockData [{ id: 1, name: John }]; axios.get.mockResolvedValue({ data: mockData }); const data await fetchData(); expect(data).toEqual(mockData); expect(axios.get).toHaveBeenCalledWith(/api/data); }); test(handles error, async () { axios.get.mockRejectedValue(new Error(Network error)); await expect(fetchData()).rejects.toThrow(Network error); }); }); // 3. 测试行为而不是实现 // component.test.js import { render, screen, fireEvent } from testing-library/react; import Component from ./Component; describe(Component, () { test(displays greeting when button is clicked, () { render(Component /); const button screen.getByText(Click me); fireEvent.click(button); expect(screen.getByText(Hello World)).toBeInTheDocument(); }); }); // 4. 集成测试 // integration.test.js import { render, screen, fireEvent } from testing-library/react; import App from ./App; describe(App, () { test(submits form successfully, () { render(App /); const nameInput screen.getByLabelText(Name); const submitButton screen.getByText(Submit); fireEvent.change(nameInput, { target: { value: John } }); fireEvent.click(submitButton); expect(screen.getByText(Form submitted successfully)).toBeInTheDocument(); }); }); // 5. 端到端测试 // cypress/integration/form.spec.js describe(Form, () { it(submits form successfully, () { cy.visit(/); cy.get(input[namename]).type(John); cy.get(button[typesubmit]).click(); cy.contains(Form submitted successfully).should(be.visible); }); });测试工具选择指南单元测试Jest适合JavaScript和React应用Mocha灵活可与不同断言库配合VitestVite生态的测试工具速度快组件测试React Testing Library测试行为而不是实现Enzyme提供更多DOM操作方法Vue Test UtilsVue官方测试工具集成测试Cypress端到端测试可视化Playwright支持多种浏览器PuppeteerGoogle开发的浏览器自动化工具测试覆盖率Istanbul代码覆盖率工具Jest内置覆盖率报告Codecov覆盖率可视化平台毒舌点评前端测试就像健身——刚开始觉得很痛苦但坚持下来就会有收获。但很多开发者就是懒不愿意写测试结果代码质量差bug一堆。我就想问一句你写的代码是给人用的还是给自己看的如果你的代码没有测试你怎么保证它能正常工作还有那些写测试的写了一堆没用的测试用例测试实现细节结果代码一重构测试全失败。你说这能怪谁还有那些测试依赖外部环境的每次测试都要调用真实API结果测试不稳定时好时坏。你就不能mock一下吗还有那些测试代码质量差的没有断言测试永远通过你说这样的测试有什么用作为一名前端手艺人我想对所有开发者说别再忽视测试了好的测试能帮助你发现bug提高代码质量让你的开发更有效率。记住测试不是目的而是手段。它是为了保证代码质量不是为了增加代码复杂度。最后我想说写测试要用心要写有意义的测试不要为了测试而测试。选择合适的测试工具合理编写测试用例这样才能发挥测试的最大价值。所以从今天开始认真写测试吧让你的代码更可靠让你的开发更高效。

相关文章:

前端测试吐槽:别再写那些没用的测试了!

前端测试吐槽:别再写那些没用的测试了! 毒舌时刻 前端测试就像体检——每个人都知道要做,但真正认真做的没几个。Jest、React Testing Library、Cypress... 一堆测试工具让你挑花了眼,结果你的测试还是写得像一坨屎。 我就想不明白…...

【数据结构】线索二叉树之中序遍历线索化详解与实现

在二叉树的遍历过程中,我们会发现大量的空指针域被浪费,而线索二叉树的核心思想就是利用这些空指针,将其指向节点的前驱或后继节点,从而实现二叉树的非递归遍历无需借助栈,提升遍历效率。本文将详细讲解中序遍历线索化…...

2026-04-02 打卡第 2 天

# 2026-04-02 打卡第 2 天 # 列表 """ li [1,2,a] print(li) # 输出结果:[1, 2, a] """# 列表中添加元素 # 整体添加 append """ li [a,b,c] li.append(d) print(li) # 输出结果:[a, b, c, d] "&qu…...

【数据结构与算法】第24篇:哈夫曼树与哈夫曼编码

一、基本概念1.1 带权路径长度在二叉树中:路径长度:从一个节点到另一个节点经过的边数带权路径长度(WPL):所有叶子节点的权重 路径长度 之和示例:text叶子节点:A(7), B(5), C(2), D(4)普通树:15/ \7 8/…...

创意随笔:智能转录便携终端

创意随笔|智能转录便携终端 项目构想 核心亮点 以独立麦克风拾音为核心入口,实现全链路闭环实时翻译 从收音、ASR 识别、翻译、TTS 合成到语音播放/耳机输出,全程不依赖手机或电脑算力,自成一套完整翻译系统,真正做到端…...

技术创业中的风险管理:从内核开发到商业稳定

技术创业中的风险管理:从内核开发到商业稳定 技术创业的风险挑战 作为一名从Linux内核开发者转型产品经理再到科技创业者的人,我深刻体会到风险管理在技术创业中的重要性。技术创业过程中充满了各种风险,从技术风险到商业风险,从市…...

嵌入式开发中的策略模式应用与优化

1. 策略模式在嵌入式开发中的核心价值在嵌入式系统开发中,我们经常遇到这样的场景:同一个功能模块需要根据不同的硬件环境、运行状态或外部条件采用不同的处理算法。传统做法是使用大量的if-else或switch-case语句,但这种做法会带来几个显著问…...

技术创业中的产品迭代:从内核开发到用户中心

技术创业中的产品迭代:从内核开发到用户中心 产品迭代的重要性 作为一名从Linux内核开发者转型产品经理再到科技创业者的人,我深刻体会到产品迭代在技术创业中的重要性。一个成功的产品不是一蹴而就的,而是通过不断的迭代和优化逐步发展起来的…...

【图像加密】基于 AES算法的图像位平面加密解密算法附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室👇 关注我领取海量matlab电子书和…...

OpenClaw性能调优实战:Qwen3-32B在RTX4090D上的量化推理加速

OpenClaw性能调优实战:Qwen3-32B在RTX4090D上的量化推理加速 1. 为什么需要性能调优? 去年冬天,当我第一次在RTX4090D上部署Qwen3-32B模型时,本以为24GB显存足以轻松应对各种任务。但现实很快给我上了一课——一个简单的网页内容…...

IBM与Arm合作推进双架构主机系统开发

IBM和Arm宣布合作开发能够运行IBM和Arm双重工作负载的硬件,使Arm软件能够在IBM主机上运行。两家公司计划在三个方面展开合作:构建虚拟化工具,让Arm软件能够在IBM平台上运行;确保Arm应用程序符合受监管行业必须遵循的安全和数据驻留…...

AWS推出新工具简化量子纠错开发流程

谷歌近日将量子计算机实用化时间表提前至2029年,这得益于量子计算机硬件、量子纠错和算法方面的重大改进。2019年,谷歌估计需要2000万个量子比特才能破解RSA加密。到2025年5月,谷歌将这一估计数字下调至100万个。今年2月,澳大利亚…...

DuinoMemory:面向Arduino的轻量级嵌入式智能指针库

1. 项目概述DuinoMemory 是一款专为 Arduino 及资源受限嵌入式系统设计的轻量级智能指针库。它不依赖 STL、不使用异常(exceptions)、不启用 RTTI,完全以头文件形式提供(header-only),所有实现均通过 C 模板…...

作家使用AI写小说:写作者必须接纳人工智能但我们依然珍贵

我最近在游乐场听到一段对话,这比任何分析师对泡沫的预测都更应该让AI公司高管担忧。一个男孩和一个女孩,大概10岁,正在争吵。"那是AI!那是AI!"女孩喊道。她的意思是男孩在沉溺于一种新的特殊胡言乱语&#…...

OpenAI收购科技脱口秀TBPN,力图塑造AI叙事话语权

OpenAI正通过收购备受硅谷内部人士关注的科技脱口秀TBPN进军媒体行业,该节目主持人周三宣布了这一消息。联合主持人约翰库根和乔迪海斯每个工作日从洛杉矶直播TBPN节目三小时,邀请的嘉宾包括创业者、风险投资家和科技界重要人物。此次交易的财务条款未予…...

OpenClaw压力测试:千问3.5-27B持续运行48小时稳定性报告

OpenClaw压力测试:千问3.5-27B持续运行48小时稳定性报告 1. 测试背景与设计思路 上周在星图平台部署了千问3.5-27B镜像后,我决定对OpenClaw框架进行极限压力测试。这个想法源于实际需求——作为独立开发者,经常需要AI助手连续处理夜间数据抓…...

嵌入式开发中PC与嵌入式思维的融合实践

1. 嵌入式开发中的PC思维与嵌入式思维融合作为一名从PC端开发转向嵌入式领域的工程师,我深刻体会到两种思维方式的差异与互补。PC编程注重抽象层次和开发效率,而嵌入式编程则必须关注硬件特性和实时性。真正的高手往往能将二者有机结合。在嵌入式领域&am…...

嵌入式软件架构设计:基础设施层实践指南

1. 嵌入式软件架构设计概述作为一名在嵌入式领域摸爬滚打多年的工程师,我深知软件架构设计的重要性。很多人认为架构设计是资深工程师的专利,其实不然。就像盖房子需要先打地基一样,任何规模的嵌入式项目都需要合理的架构设计作为基础。嵌入式…...

电动关节机械手设计【任务书+说明书+CAD图纸】 电动关节机器人

电动关节机械手作为工业自动化领域的核心装备,通过电机驱动实现多自由度运动控制,在物料搬运、装配加工等场景中承担关键操作任务。其核心作用在于替代人工完成重复性高、精度要求严苛的作业,例如精密电子元件的抓取、重型工件的定位等&#…...

4大技术方案解决WarcraftHelper工具的《魔兽争霸III》兼容性与性能优化问题

4大技术方案解决WarcraftHelper工具的《魔兽争霸III》兼容性与性能优化问题 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper WarcraftHelper是一款专注…...

折腾光纤模型的手记

comsol仿真-W型光子晶体光纤色散与损耗分析效果展示最近在实验室被导师催着搞光子晶体光纤的仿真,W型结构这种带双包层设计的玩意儿确实有点意思。作为COMSOL萌新,边啃说明书边试错,折腾一周终于把色散曲线和损耗谱给整明白了。先说建模这个重…...

针对双SMC控制的四轮转向轨迹跟踪模型优化与效果评估研究

四轮转向4WS轨迹跟踪控制模型 采用双SMC控制 4WS通过积分滑模控制跟踪期望横摆角速度和质心侧偏角,效果很好~ 轨迹跟踪为双移线输入,采用积分滑模控制 【特别说明】 是针对两篇论文的控制进行复现哦~ 提供参考文献及模型文件 最近在复现四轮转向轨迹跟踪…...

直接可用4轴插补算法库,STM32的DDA插补联动与梯形加减速算法代码

可以直接使用的4轴插补算法库,不是丢给你一堆gr1b或者写字机或者3d打印的开源代码,本运控库上项目级别的,需要添加在自己的项目中,不支持gm码,只有运动控制核心代码,可以添加在自己项目中的,stm…...

光储并网直流微电网仿真模型(matlab/simulink,2018),包含: 1.MPPT模块

光储并网直流微电网仿真模型(matlab/simulink,2018),包含: 1.MPPT模块,实现光伏输入最大功率跟踪; 2.储能电池模块; 3.超级电容模块; 控制策略简介: 糸统使用…...

质子交换膜(PEM)燃料电池氢气供应系统,阳极压力非线性状态控制simulink模型;自适应反...

质子交换膜(PEM)燃料电池氢气供应系统,阳极压力非线性状态控制simulink模型;自适应反步法控制; 燃料电池电堆模型:阴极流道,阳极流道,膜水合传递,输出电压模型、 氢气回路…...

MAX9814麦克风音量LED指示器嵌入式固件库

1. 项目概述MAX9814_Electret_Microphone_LED_Volume_Indicator是一个面向嵌入式音频前端采集与可视化反馈的轻量级固件库,专为 Adafruit MAX9814 电容式驻极体麦克风放大模块设计。该模块基于 Maxim(现为 Analog Devices)推出的低噪声、高增…...

L293D电机驱动库:嵌入式直流电机控制实战指南

1. L293D电机驱动库深度解析:面向嵌入式工程师的工程实践指南L293D是TI(德州仪器)推出的双H桥直流电机驱动芯片,广泛应用于Arduino、ESP32等微控制器平台的中小功率直流电机控制场景。本库并非简单封装GPIO操作,而是针…...

C语言整数字节拆解:联合体与移位操作详解

1. 理解题目:整数字节拆解的核心需求 在嵌入式开发和底层系统编程中,处理多字节数据是家常便饭。就拿这个面试题来说,我们需要从32位无符号整数0x12345678中提取出它的四个独立字节。这看似简单的需求背后,其实涉及到计算机系统中…...

剪映自动化工具来了:AI帮你自动剪辑成片

文章目录 📖 介绍 📖 🏡 演示环境 🏡 📒 AI赋能剪映自动化剪辑 📒 🎯 设计理念 🔧 核心功能 📦 安装与使用 ⚓️ 相关链接 ⚓️ 📖 介绍 📖 在视频创作中,剪辑工作往往耗时耗力。从素材导入、字幕匹配、BGM选择到最终导出,每一个环节都需要创作者投入大…...

从裸机开发到RTOS:嵌入式系统进阶指南

1. 裸机开发的本质与局限性裸机开发,顾名思义就是在没有任何操作系统支持下直接对硬件进行编程。这种方式在嵌入式系统入门阶段非常普遍,尤其适合资源极其有限的8位单片机(如51系列)或简单应用场景。但当我们面对STM32这类性能强大…...