diff --git a/README.md b/README.md index 4fe43c3..bbe5f7d 100644 --- a/README.md +++ b/README.md @@ -42,9 +42,9 @@ Selectors are located in `cypress/selectors` folder [only difference from cypres ## :grey_question: Q&A 1. Why keep selectors separately (not hard-coded to tests) - - selector and test logic is separated - when selector is updated, we just need to update selector file and not tests - - css selectors are by nature hard to read - even if we add data-test attributes. We might need 2nd child or want to verify that selector is a child for another element, like `.class2 > ul:nth-child(2)` (alternative `get().find()` or `get().parent()` is bad practice because of [this](https://docs.cypress.io/guides/core-concepts/retry-ability.html#Only-the-last-command-is-retried) ) + - **tests are much more readable** - css selectors are by nature hard to read - even if we add data-test attributes. We might need 2nd child or want to verify that selector is a child for another element, like `.class2 > ul:nth-child(2)` (alternative `get().find()` or `get().parent()` is bad practice because of [this](https://docs.cypress.io/guides/core-concepts/retry-ability.html#Only-the-last-command-is-retried) ) - in large projects, we might need to re-use the same selectors. Example: in login test, we want to verify that login was successful and we check settings link in header. But the same settings link is also tested in header test. + - selector and test logic is separated - when selector is updated, we just need to update selector file and not tests 3. Why mobile view is in config and not in test (like cy.viewport())? - we can't change userAgent in the middle of the test: https://github.com/cypress-io/cypress/issues/2100