首页 > 解决方案 > 赛普拉斯测试的随机元素选择

问题描述

目前正在测试一个本地电影预订网站,我必须在其中输入选定电影的一定数量的票。此处附加屏幕的屏幕截图 -

在此处输入图像描述

用于重现问题的存储库 - https://github.com/zac11/iCinema

  1. 克隆回购。
  2. 进入client目录并执行npm i
  3. npm start从根目录运行。
  4. Webapp 将在localhost:3000

我希望能够以随机方式输入所选电影的电影票,这样它可以选择四张票中的随机类别并输入票号,例如 2

现在我可以通过以这种方式对定位器进行硬编码来填写票证类别 -

  cy.get('div.tickets-info > div:nth-child(1) > span > b').type(3,{force:true});

输入Junior Ticket类别的票数。我希望能够在四个类别中的任何一个类别中随机输入一张票,而无需对类别定位器进行硬编码。

PS - 存储库包含柏树测试也可以使用npm run test

标签: javascriptcypresse2e-testing

解决方案


您可以根据以下内容随机化类别:

const picked = Math.floor(Math.random()*3); // this gives you a random value from 0 - 3;

// using template string literals - we can add that into picked
cy.get(`div.tickets-info > div:nth-child(`${picked}`) > span > b`).type(3, {force: true})

从picked - 你可以有一个与类别相关的元素数组:

const categories = ["Junior", "student", "normal", "senior"]

您还可以将门票的值categories作为对象并将其用于计算总数。

const categories = [{
  type: "junior", 
  value: 5
}, {
  type: "student",
  value: 3
}, {
  type: "normal"
  value: 10
}, {
  type: "senior",
  value: 3
}]

你可以说,使用选择的值来计算总金额

const value = categories[picked].value * random_amount;
cy.get(".sum-field label:nth-child(1)").should("contain", value) // total

推荐阅读