A Node.js tool to automate end-to-end web testing.
Write tests in JS or TypeScript, run them and view results.
npm install -g testcafe
Running a sample test in Safari
Stable tests and no manual timeouts
TestCafe automatically waits for page loads and XHRs before the test starts and after each action. It also features smart test actions and assertions that wait for page elements to appear. You can change the maximum wait time. If elements load faster, tests skip the timeout and continue.
Latest JS and TypeScript support
Detects JS errors in your code
TestCafe reports JS errors that it finds on the webpage. Tests automatically fail because of that. However, you can disable this.
Concurrent tests launch
TestCafe can open multiple instances of the same browser to run parallel tests which decreases test execution time.
const macOSInput = ;
Easy to include in a continuous integration system
You can run TestCafe from a console, and its reports can be viewed in a CI system's interface (TeamCity, Jenkins, Travis & etc.)
npm install -g testcafe
As an example, we are going to test the https://devexpress.github.io/testcafe/example page.
.ts file on your computer.
Note that it needs to have a specific structure: tests must be organized into fixtures.
You can paste the following code to see the test in action:
; // first import testcafe selectorsfixture `Getting Started`// declare the fixturepage ``; // specify the start page//then create a test and place your code there;
testcafe chrome test1.js
TestCafe opens the browser and starts executing the test.
Important! Make sure to stay in the browser tab that is running tests. Do not minimize the browser window. Tests are not guaranteed to execute correctly in inactive tabs and minimized browser windows because they switch to a lower resource consumption mode.
Read the Getting Started page for a more detailed guide.
Go to our website for full documentation on TestCafe.
Follow us on Twitter. We post TestCafe news and updates, several times a week.
Show everyone you are using TestCafe:
To display this badge, add the following code to your repository readme:
Report bugs and request features on our issues page.
Ask questions and participate in discussions on the discussion board.
For more information on how to help us improve TestCafe, see the CONTRIBUTING.md.
You can use these plugin generators to create your own plugins:
If you want your plugin to be listed below, send us a note in a Github issue.
TestCafe developers and community members made these plugins:
Allow you to use TestCafe with cloud browser providers and emulators.
Work with page elements in a way that is native to your framework.
Plugins for Task Runners
Integrate TestCafe into your project's workflow.
View test results in different formats.
Find accessibility issues in your web app.
Run tests and view results from your favorite IDE.
Use ESLint when writing and editing TestCafe tests.
We are grateful to BrowserStack for providing the infrastructure that we use to test code in this repository.
Code released under the MIT license.
Developer Express Inc. (https://devexpress.com)