🚧 WARNING: Testeranto is still under development and is not ready for production yet. 🚧
home: adamwong246.github.io/testeranto
source: github.com/adamwong246/testeranto
npm: npmjs.com/package/testeranto
dev: github.dev/adamwong246/testeranto
example repo: kokomo bay
- Do you like TDD/BDD?
- Do you love Typescript?
- Do you hate Jira?
If so, then testeranto might be the testing tool you have been looking for!
Testeranto.ts an typescript Acceptance Test Driven Development (ATDD) framework. It includes a library of common patterns to help write your tests, a test runner to schedule the tests and a reporter to display the results. The tests are specified in a strongly-typed gherkin-like syntax. Features are tracked as code, rather than living in a separate app. Tests can be run in the browser frontend or the node backend, or both! Testeranto can be used to test anything that can be bundled with esbuild.
- Write some code.
- Write some tests of that code.
- Write some features of that code.
- Write a
testeranto.mts
, which acts as a config file. - Launch testeranto. The test runner is now rebuilding the docs folder.
- Commit the results of those tests.
- Your github pages now shows your report, showing your features, linked with your test results.
- Optionally add testeranto to your CI.
- esm - Testeranto uses modern js.
- typescript - tests are functions with type parameters
- puppeteer - provides access to both node and chrome runtimes
- esbuild - used to quickly generate test bundles
- graphology - used to store features within a semantic network
-
Rather than testing your code directly, Testeranto requires you wrap your code with a semantic interface which is based on TS type signatures. These interfaces can be shared and your code is tested through the gherkin-ish directives provided by that interface.
-
Testeranto tracks features and tests results directly in the source code. You may be accustomed to using tools like Jira and Trello to define user stories and assign story points. Using Testeranto, this data lives within the code base as typescript code. Features are defined as nodes within a directed graph, allowing the reporter to summarize these features and their test results.
-
Testeranto is designed for both the backend and the frontend. It leverages puppeteer to provide both of these runtimes. Each of your tests can be executed in the backend node runtime, within the frontend chromium browser runtime, or both.
Your tests can be run in node, chromium, or both.
Testeranto includes a test runner which bundles and executes your tests, taking care to only run the tests which have changed.
Testeranto includes a test reporter which displays the state of your code in a web app. (see example) This reporter can also be run locally for the developer's convenience.
Testeranto exposes an extended gherkin syntax. You can use the given-when-then lingua-franca, AND you can also use an imperative Check
which is a bit more flexible.
Rather than the traditional method of specifying tests in plain text, Testeranto tests and features are just TS, editable and type-checkable from github's online editor!
Testeranto is very flexible and unopinionated, but not designed to maximize performance.
Testeranto does not (yet!) allow a means of allowing non-coders to affect changes so, as they say, "git good 💪!"
Testeranto uses ONLY node v8 and chromium. It does not support bun or deno, nor firefox nor safari.
Testeranto is comprised of 3 parts
- The build process reads a config and builds the docs folder, then launches 3 esbuild build processes.
- Build the features for the html report
- Build the node-style tests
- Build the web-style tests
-
The test runner watches the output of those build processes and launches the tests as those files change. It uses puppeteer to run web tests in chromium. It uses dynamic loading to import the node tests directly into the node v8 process.
-
A Report which links your features, your tests and the results of those tests into a handy website.
There are 3 commands you should add to your package.json
// build the tests once
"testeranto-esbuild": "ts-node-esm testeranto.mts",
// build the tests, watching for changes
"testeranto-esbuild-dev": "ts-node-esm testeranto.mts",
// run the tests
"testeranto-puppeteer":"ts-node-esm node_modules/testeranto/dist/module/Puppeteer.js",
Consider the a scenario: You have an http server which serves a frontend react component. You have multiple ways you can test this.
- A node test of the logic of the http server.
- A node test of the full http server, tested over http request.
- A node test of the react component with react-test-render
- A web test of the react component rendering it to the dom.
- A node test of the logic of the server, rending the component as a paired artifact and communicated over IPC.
- A node test of the full server, invoking puppeteer to drive the browser.
- A web test, invoking the server as a shared artifact, serving http to the browser.
Testeranto's main API interface is 2 functions, 1 for each run time. You must pass to this function the following arguments
- The "shape" - a TS type signature to which the other arguments must conform.
- The "input" - the test subject. The "thing that is to be tested"
- the "specification" - This is the Cucumber-style Given/When/Then steps.
- the "implementation" - This is the code which implements the "test specification" in code.
- the "interface" - The code which sets up the test.
This is designed so that each piece can be worked upon separately. You can think of each argument as the responsibility of a different member of your team.
- "Senior Engineer" handles the "shape" and "input"
- "Product Manager" handles the "specification"
- "Middle Engineer" handles the "interface"
- "Junior Engineer" handles the "implementation"