admin管理员组文章数量:1415484
I am wondering the best way to tackle this problem:
- I have multiple DOM elements that I want to iterate through, they all have the same src path aside from the character name.
- I want to validate that each src matches any player name value from an array
const playerName = ["_player_One_", "_player_two_", "_player_three_", "_player_four_"]
cy.get("myElement").each(($match) => {
cy.wrap($match).each(($el) => {
cy.get($el).should("include.attr", "src", `/foo/bar/art/all-art-${playerCharacter[]}.png`);
});
});
I recognise in it's current form, I'll be returned with the whole array output but I'm just sharing for reference the angle I'm ing from.
Any help would be appreciated, even if it's a new way to structure that I hadn't considered.
Thanks in advance!
I am wondering the best way to tackle this problem:
- I have multiple DOM elements that I want to iterate through, they all have the same src path aside from the character name.
- I want to validate that each src matches any player name value from an array
const playerName = ["_player_One_", "_player_two_", "_player_three_", "_player_four_"]
cy.get("myElement").each(($match) => {
cy.wrap($match).each(($el) => {
cy.get($el).should("include.attr", "src", `/foo/bar/art/all-art-${playerCharacter[]}.png`);
});
});
I recognise in it's current form, I'll be returned with the whole array output but I'm just sharing for reference the angle I'm ing from.
Any help would be appreciated, even if it's a new way to structure that I hadn't considered.
Thanks in advance!
Share Improve this question asked Aug 24, 2021 at 10:05 BLBBLB 491 silver badge4 bronze badges2 Answers
Reset to default 4Convert player names to links array, assert with 'oneOf'.
Works if player's elements change order.
const players = ["_player_One_", "_player_two_", "_player_three_", "_player_four_"]
const links = players.map(player => `/foo/bar/art/all-art-${player}.png`)
it('all elements have a player', () => {
cy.get('div[src^="/foo/bar/art/all-art-"]')
.each($el => {
cy.wrap($el).invoke('attr', 'src').should('be.oneOf', links)
})
})
it('all players have an element', () => {
cy.get('div[src^="/foo/bar/art/all-art-"]')
.then($els => {
const attrLinks = [...$els].map($el => Cypress.$($el).attr('src'))
links.forEach(link => {
cy.wrap(link).should('be.oneOf', attrLinks)
})
})
})
You can do something like this:
const playerName = ["_player_One_", "_player_two_", "_player_three_", "_player_four_"]
cy.get('myElement').each(($ele, index) => {
expect($ele.attr('src')).to.include(playerName[index])
})
版权声明:本文标题:javascript - Cypress: how to check if a string interpolation contains any value from an array - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1745233880a2648943.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论