- Failure is Feedback
- Posts
- ✅ Quick Tip: Use Cypress to find your .parents()
✅ Quick Tip: Use Cypress to find your .parents()
data:image/s3,"s3://crabby-images/3d843/3d843d73dcace771aa79469ca0e1086f5dca0864" alt=""
Sometimes, automating a test is straightforward, and sometimes, it’s not. Take grids for example. Adding data-testids helps but there are times when you may not be able to be able to easily select the element you need. Sometimes, the only thing you can do is turn to your .parents()
TL;DR Use .parents() to track which parent element you need to select
cy.get(".rt-td").parents()
Once, we know which parent to select, we can use .find() to select the element we want to take action on.
Let’s use DemoQA’s Web Tables page to test this out.
data:image/s3,"s3://crabby-images/925fb/925fb703f472db6937c4ab78d3e653a908431156" alt=""
Let’s say we need to automate clicking the edit button in a row. We could use the #id available to us…
data:image/s3,"s3://crabby-images/0b167/0b1676e4f292d265ff2ee66b7c461cce13911bd5" alt=""
But what if we wanted to make sure that we are editing the “right” row that includes the name “Cierra”?
Here’s how we can do that.
beforeEach(() => { cy.visit("https://demoqa.com/webtables");});describe("Find the parents", () => { it("Select the parent element to edit the correct row", () => { cy.get(".rt-td").contains("Cierra").parents(); });});
At first, we’ll leave .parents() empty. Let’s see what happens! 😁
data:image/s3,"s3://crabby-images/1fd99/1fd995b590ea7d7d4432a64ce76d732c3efec7df" alt=""
We have sooooo many parents to choose from! But, we only need the parent of the row we want to edit.
Using the Cypress dashboard, click the “parents” displayed in the UI.
data:image/s3,"s3://crabby-images/e5a16/e5a16393887065ee4a65fdae48627d744aeeac32" alt=""
Clicking “parents” pins the results in the devTools console inside of Cypress! Right-click “parents” and select “Inspect”
data:image/s3,"s3://crabby-images/4fe12/4fe1286a3b09410dc1d5b95fc30e5f4f1eeefc23" alt=""
Click the “Console” tab
data:image/s3,"s3://crabby-images/cfeaa/cfeaa15d26777713e00477f1d11d976a1133c09a" alt=""
Here are our choices. Sometimes the choice is clear and sometimes it isn’t. We can go back and check the DOM tree structure or use some good old trial and error to find the parent you need.
cy.get(".rt-td") .contains("Cierra") .parents("div.rt-tr-group")
data:image/s3,"s3://crabby-images/af65d/af65d7e44ac19c57bc4dfbf62ac705bf99a7cdff" alt=""
Sweet! That selected the whole row! Now, we can pair .find() with .parents() and click the edit button.
cy.get(".rt-td") .contains("Cierra") .parents("div.rt-tr-group") .find("#edit-record-1")
Here’s what it looks like before the button is clicked:
data:image/s3,"s3://crabby-images/9c0cb/9c0cbad27c3a4b1ffc738c2d3abdd4899cdef2b4" alt=""
Now, let’s add .click()
cy.get(".rt-td") .contains("Cierra") .parents("div.rt-tr-group") .find("#edit-record-1") .click();
💥 Boom!
data:image/s3,"s3://crabby-images/5697e/5697e645ecf06cb199e762606a5216b98b3d17d3" alt=""
There’s the registration form!
Here is what our test looks like:
beforeEach(() => { cy.visit("https://demoqa.com/webtables");});describe("Find the parents", () => { it("Select the parent element to edit the correct row", () => { cy.get(".rt-td") .contains("Cierra") .parents("div.rt-tr-group") .find("#edit-record-1") .click(); });});
In automation, sometimes, all we need is a little guidance. In a pinch, .parents() can help us find our way.
Till next time…
data:image/s3,"s3://crabby-images/69761/6976149a9c269665716454747e4d5e59b9e1f8ac" alt=""
All my posts are free to read and clicking subscribe will bring each post to your inbox. If my work brings you joy, and you’d like to support it, you can become a paid subscriber by clicking the button above. If a paid subscription is not your thing, you can support my caffeine addiction writing by clicking the button below! Thanks!
Written with Ultimate Spacefolk Banjo Compilation || 2+ Hours Ethereal Vibes Playlist playing in the background
Reply