首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >有没有办法在Cypress测试中创建一个别名/变量/命令来重复静态代码块?

有没有办法在Cypress测试中创建一个别名/变量/命令来重复静态代码块?
EN

Stack Overflow用户
提问于 2020-09-04 18:16:08
回答 1查看 39关注 0票数 0

我正在测试一个非常长的表单页面,其中包含12个输入域。我基本上是在测试表单页面的自动保存功能。因此,测试逻辑是访问每个字段,键入一个值,然后检查报头是否具有savingsaved状态消息。然后重新加载页面,看看输入字段是否保留了它的值。例如。

代码语言:javascript
复制
// Aliases for the input fields
cy.get('div[name="title"] input').as('Title');
cy.get('div[name="location"] input').as('Location');
cy.get('div[name="duration"] input').as('Duration');
....


cy.get('@Title').type(randomTitle);


// @Testing save status and reload -------------------
cy.get('.form-header').within(() => {
  cy.contains('SAVING');
  cy.contains('SAVED');
});
cy.reload();
//----------------------------------------------------


cy.get('@Title').then((elem) => {
  expect(elem.val()).to.equal(randomTitle);
});

一切都很好,但是我希望如果我能重构代码,使它更干净。我看到的唯一问题是我实际上重复了12次@Testing save status and reload代码块。在Cypress中有没有我可以创建一个别名、变量或命令来运行带有一个一行的特定块?有可能吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-05 23:32:44

我真是个笨蛋,这个问题的答案就在标题本身。我所要做的就是在命令文件中创建一个这样的命令。

代码语言:javascript
复制
const checkSaveStatus = () => {
cy.get('.form-header').within(() => {
  cy.contains('SAVING');
  cy.contains('SAVED');
});
cy.reload();
};
Cypress.Commands.add('checkSaveStatus', checkSaveStatus);

在我的测试中调用它,就像这样

代码语言:javascript
复制
cy.checkSaveStatus();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63739186

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档