A Suite of JavaScript libraries and framework extensions to help you
answer the question:
Does my application work in real life?
BigTest is an innovative new test runner. It is built to test any web application in any browser and do it with great performance and test stability.
BigTest is under heavy development, we are currently at an alpha stage of development, and adventurous users can start using BigTest today. Want to help us get to Beta? Check out the beta milestone and help us cross the finish line!
The surest way to know if an application is going to work is to actually run it. BigTest is built to work with any web application out of the box and requires zero integration inside your application code. From frontend applications to server side rendered, React, Angular, Vue, Ember and so on… If you can build it, you can test it.
Does your appication run in a browser? Then if a test is going to measure whether it works or not, it also needs to run in a real browser that a real user might use. BigTest is built from the ground up to work with any browser, including mobile browsers.
Testing big is hard because there can be hundreds if not thousands of things happening concurrently inside your application, including user interactions. We have taken great care to make sure BigTest tests do not suffer from the flakiness issues often associated with big tests. Read about how we eliminate flakiness on our blog.
BigTest is currently alpha level software and we are still building documentation, so be prepared for some roughness around the edges, but if you already want to give it a go, here is how you can get going:
Install bigtest in your application:
yarn add bigtest @bigtest/cli @bigtest/suite @bigtest/interactor
Add a bigtest.json
file in the root of your project with a base configuration like this:
{
"app": {
"command": "yarn start",
"env": { "PORT": 36000 },
"url": "http://localhost:36000"
},
"launch": ["chrome.headless"]
}
You can replace yarn start
with however you start your application. In the
future there will be an init
command to set up this file.
Add a test file in test/my-test.test.js
:
import { App, Headline } from '@bigtest/interactor';
import { test } from '@bigtest/suite';
export default test('My Test')
.step(App.visit('/'));
.step(Headline("My Application").exists());
Start the BigTest server:
yarn bigtest server
And run your tests:
yarn bigtest run
- Clone this repository
git clone git@github.com:thefrontside/bigtest.git
- Run
yarn
Many of the packages in this repository depend on each other in order to function. However, being assembled from TypeScript and HTML webapps, these packages need to be built before they can be consumed. In order to build dependencies
$ yarn prepack
This will compile each package into the state in which it will ultimately appear on NPM.
- Run
yarn
to ensure that all dependencies are installed - Run
yarn prepack
to build all packages - Run
yarn test
to run automated tests
- Run
yarn
to ensure that all dependencies are installed - Run
yarn prepack
to build all packages - Run
yarn lint
to run linters