端到端(E2E)测试可验证从头到尾的应用流量。连续集成(CI)不是手动测试,而是自动化此过程。编写代码,保存并让工具确保其不会破坏现有功能。赛普拉斯是一个强大的E2E测试框架,可简化此过程,特别是对于像React这样的现代JavaScript库。
设置测试应用程序
本教程使用示例待办器应用程序。克隆存储库以进行以下操作:
git克隆[电子邮件保护]:sinsomicrote/cypress-react-tutorial.git
导航到目录并安装依赖项:
CD柏树反应教程 纱线安装
安装柏树:
纱线添加柏树 - dev
开放柏树:
node_modules/.bin/Cypress打开
要更轻松地访问,请将此脚本添加到package.json
:
“脚本”:{ “柏树”:“柏树打开” }
现在,运行yarn cypress
以打开柏树。使用yarn start
查看应用程序。
让我们在cypress/integration/init.spec.js
中创建一个基本测试:
描述('Cypress',()=> { 它('正在工作',()=> { 期望(true).to.equal(true); }); });
这证实柏树正在起作用。现在,让我们测试访问该应用程序:
它('访问app',()=> { cy.visit('http:// localhost:3000'); });
为避免重复URL,请在cypress.json
中设置一个基本URL。
{ “ baseurl”:“ http:// localhost:3000” }
现在可以简化测试以:
它('访问app',()=> { cy.visit('/'); });
测试表单控件和输入
创建cypress/integration/form.spec.js
来测试用户交互。
描述('form',()=> { each(()=> { cy.visit('/'); }); 它('focus the Input',()=> { cy.focused()。应该('ham ham class','form-control'); }); 它('接受输入',()=> { const Input =“关于柏树”; cy.get('。形式控制') .Type(输入) 。 }); it('显示todos',()=> { cy.get('li')。应该('have.length',2); }); 它('添加一个新的todo',()=> { const Input =“关于柏树”; cy.get('。形式控制') .Type(输入) .type('{enter}') .get('li') 。 }); 它('删除todo',()=> { cy.get('li') 。第一的() .find('。btn-danger') 。点击() .get('li') 。 }); 它('删除所有todos',()=> { cy.get('li') 。第一的() .find('。btn-danger') 。点击() .get('li') 。第一的() .find('。btn-danger') 。点击() .get('。否任务') 。 }); });
这些测试涵盖了输入焦点,输入接受,初始todo计数,添加了新的todo,删除单个待办事项,并删除了所有Todos。
测试网络请求
测试网络请求确保数据获取正常工作。例如,使用JSON占位符API:
描述('请求',()=> { 它('显示API的随机用户,()=> { cy.request('https://jsonplaceholder.typicode.com/users') 。 期望(响应status).e.eq(200); 期望(响应body).have.length(10); 期望(响应).have.property('标题'); 期望(响应)。 }); }); });
这将验证API响应状态,数据长度和响应属性。
从命令行运行测试
从终端运行柏树测试:
NPX柏树运行
进行特定的测试:
npx柏树运行 - 规格“柏树/integration/form.spec.js”
这提供了测试结果的命令行摘要。有关更高级的命令行选项,请参阅柏树文档。
结论
赛普拉斯简化了E2E测试,使其对开发人员易于访问和有益。该教程展示了中间测试技术的基础,鼓励您进一步探索其功能。请记住要查阅柏树文档以获取更高级的功能和最佳实践。
以上是使用柏树为React应用程序编写测试的详细内容。更多信息请关注PHP中文网其他相关文章!

在这篇文章中,布莱克·莫里(Blackle Mori)向您展示了一些骇客,同时试图推动同位HTML支持的极限。如果您敢于使用这些,以免您也被标记为CSS罪犯。

具有CSS的自定义光标很棒,但是我们可以将JavaScript提升到一个新的水平。使用JavaScript,我们可以在光标状态之间过渡,将动态文本放置在光标中,应用复杂的动画并应用过滤器。

互动CSS动画和元素相互启动的元素在2025年似乎更合理。虽然不需要在CSS中实施乒乓球,但CSS的灵活性和力量的增加,可以怀疑Lee&Aver Lee&Aver Lee有一天将是一场

有关利用CSS背景滤波器属性来样式用户界面的提示和技巧。您将学习如何在多个元素之间进行背景过滤器,并将它们与其他CSS图形效果集成在一起以创建精心设计的设计。

好吧,事实证明,SVG的内置动画功能从未按计划进行弃用。当然,CSS和JavaScript具有承载负载的能力,但是很高兴知道Smil并没有像以前那样死在水中

是的,让#039;跳上文字包装:Safari Technology Preview In Pretty Landing!但是请注意,它与在铬浏览器中的工作方式不同。

此CSS-tricks更新了,重点介绍了年鉴,最近的播客出现,新的CSS计数器指南以及增加了几位新作者,这些新作者贡献了有价值的内容。

在大多数情况下,人们展示了@Apply的@Apply功能,其中包括Tailwind的单个property实用程序之一(会改变单个CSS声明)。当以这种方式展示时,@Apply听起来似乎很有希望。如此明显


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境