From 04c585006f3a2dfbbd3b8f3220270607e31b2b7e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20Gandecki?= Date: Sat, 5 May 2018 14:35:20 +0400 Subject: [PATCH] feat: support queryBy* queryAllBy* (#5) * initial work for enabling queries * update docs, contributors * fixed typo --- .all-contributorsrc | 10 +++ README.md | 17 +++-- cypress/integration/commands.spec.js | 5 ++ src/__tests__/__snapshots__/commands.js.snap | 10 +++ src/index.js | 68 +++++++++++--------- 5 files changed, 76 insertions(+), 34 deletions(-) diff --git a/.all-contributorsrc b/.all-contributorsrc index effa20c..55d1b05 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -28,6 +28,16 @@ "code", "ideas" ] + }, + { + "login": "lgandecki", + "name": "Łukasz Gandecki", + "avatar_url": "https://avatars1.githubusercontent.com/u/4002543?v=4", + "profile": "http://team.thebrain.pro", + "contributions": [ + "code", + "test" + ] } ], "repoType": "github" diff --git a/README.md b/README.md index 32d919f..d932218 100644 --- a/README.md +++ b/README.md @@ -16,7 +16,7 @@ [![downloads][downloads-badge]][npmtrends] [![MIT License][license-badge]][license] -[![All Contributors](https://img.shields.io/badge/all_contributors-2-orange.svg?style=flat-square)](#contributors) +[![All Contributors](https://img.shields.io/badge/all_contributors-3-orange.svg?style=flat-square)](#contributors) [![PRs Welcome][prs-badge]][prs] [![Code of Conduct][coc-badge]][coc] @@ -42,7 +42,6 @@ This allows you to use all the useful [`dom-testing-library`][dom-testing-librar * [Installation](#installation) * [Usage](#usage) -* [Inspiration](#inspiration) * [Other Solutions](#other-solutions) * [Contributors](#contributors) * [LICENSE](#license) @@ -68,7 +67,15 @@ Add this line to your project's `cypress/support/commands.js`: import 'cypress-testing-library/add-commands'; ``` -You can now use all of `dom-testing-library`'s `getBy` and `getAllBy` commands. [See `dom-testing-library` repo for reference](https://github.com/kentcdodds/dom-testing-library#usage) +You can now use all of `dom-testing-library`'s `getBy`, `getAllBy`, `queryBy` and `queryAllBy` commands. [See `dom-testing-library` repo for reference](https://github.com/kentcdodds/dom-testing-library#usage) + +To show some simple examples (from [cypress/integration/commands.spec.js](cypress/integration/commands.spec.js)): + +```javascript +cy.getAllByText('Jackie Chan').click() +cy.queryByText('Button Text').should('exist') +cy.queryByText('Non-existing Button Text').should('not.exist') +``` ## Other Solutions @@ -82,8 +89,8 @@ Thanks goes to these people ([emoji key][emojis]): -| [
Kent C. Dodds](https://kentcdodds.com)
[💻](https://github.com/kentcdodds/cypress-testing-library/commits?author=kentcdodds "Code") [📖](https://github.com/kentcdodds/cypress-testing-library/commits?author=kentcdodds "Documentation") [🚇](#infra-kentcdodds "Infrastructure (Hosting, Build-Tools, etc)") [⚠️](https://github.com/kentcdodds/cypress-testing-library/commits?author=kentcdodds "Tests") | [
Ivan Babak](https://sompylasar.github.io)
[💻](https://github.com/kentcdodds/cypress-testing-library/commits?author=sompylasar "Code") [🤔](#ideas-sompylasar "Ideas, Planning, & Feedback") | -| :---: | :---: | +| [
Kent C. Dodds](https://kentcdodds.com)
[💻](https://github.com/kentcdodds/cypress-testing-library/commits?author=kentcdodds "Code") [📖](https://github.com/kentcdodds/cypress-testing-library/commits?author=kentcdodds "Documentation") [🚇](#infra-kentcdodds "Infrastructure (Hosting, Build-Tools, etc)") [⚠️](https://github.com/kentcdodds/cypress-testing-library/commits?author=kentcdodds "Tests") | [
Ivan Babak](https://sompylasar.github.io)
[💻](https://github.com/kentcdodds/cypress-testing-library/commits?author=sompylasar "Code") [🤔](#ideas-sompylasar "Ideas, Planning, & Feedback") | [
Łukasz Gandecki](http://team.thebrain.pro)
[💻](https://github.com/kentcdodds/cypress-testing-library/commits?author=lgandecki "Code") [⚠️](https://github.com/kentcdodds/cypress-testing-library/commits?author=lgandecki "Tests") | +| :---: | :---: | :---: | diff --git a/cypress/integration/commands.spec.js b/cypress/integration/commands.spec.js index 1e5bc9c..df03755 100644 --- a/cypress/integration/commands.spec.js +++ b/cypress/integration/commands.spec.js @@ -31,6 +31,11 @@ describe('dom-testing-library commands', () => { it('getAllByText', () => { cy.getAllByText('Jackie Chan').click({multiple: true}) }) + + it('queryByText', () => { + cy.queryByText('Button Text').should('exist') + cy.queryByText('Non-existing Button Text').should('not.exist') + }) }) /* global cy */ diff --git a/src/__tests__/__snapshots__/commands.js.snap b/src/__tests__/__snapshots__/commands.js.snap index 62deebf..5e1234a 100644 --- a/src/__tests__/__snapshots__/commands.js.snap +++ b/src/__tests__/__snapshots__/commands.js.snap @@ -2,14 +2,24 @@ exports[`exports expected commands 1`] = ` Array [ + "queryByPlaceholderText", + "queryAllByPlaceholderText", "getByPlaceholderText", "getAllByPlaceholderText", + "queryByText", + "queryAllByText", "getByText", "getAllByText", + "queryByLabelText", + "queryAllByLabelText", "getByLabelText", "getAllByLabelText", + "queryByAltText", + "queryAllByAltText", "getByAltText", "getAllByAltText", + "queryByTestId", + "queryAllByTestId", "getByTestId", "getAllByTestId", ] diff --git a/src/index.js b/src/index.js index 906ba77..fa4da0d 100644 --- a/src/index.js +++ b/src/index.js @@ -1,39 +1,49 @@ import {queries, waitForElement} from 'dom-testing-library' -const commands = Object.keys(queries) - .filter( - queryName => - queryName.startsWith('getBy') || queryName.startsWith('getAllBy'), - ) - .map(queryName => { - return { - name: queryName, - command: (cy, ...args) => { - const queryImpl = queries[queryName] - const commandImpl = doc => - waitForElement(() => queryImpl(doc, ...args), {container: doc}) - const thenHandler = new Function( - 'commandImpl', - ` +const commands = Object.keys(queries).map(queryName => { + return { + name: queryName, + command: (cy, ...args) => { + const queryImpl = queries[queryName] + const baseCommandImpl = doc => + waitForElement(() => queryImpl(doc, ...args), { + container: doc, + timeout: 3000, + }) + let commandImpl + if ( + queryName.startsWith('queryBy') || + queryName.startsWith('queryAllBy') + ) { + commandImpl = doc => + baseCommandImpl(doc).catch(_ => + doc.querySelector('.___cypressNotExistingSelector'), + ) + } else { + commandImpl = doc => baseCommandImpl(doc) + } + const thenHandler = new Function( + 'commandImpl', + ` return function Command__${queryName}(thenArgs) { return commandImpl(thenArgs.document) } `, - )(commandImpl) - return cy - .window({log: false}) - .then(thenHandler) - .then(subject => { - Cypress.log({ - $el: subject, - name: queryName, - message: args, - }) - return subject + )(commandImpl) + return cy + .window({log: false}) + .then(thenHandler) + .then(subject => { + Cypress.log({ + $el: subject, + name: queryName, + message: args, }) - }, - } - }) + return subject + }) + }, + } +}) export {commands}