Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zpratt/react-tdd-guide
A series of examples on how to TDD React
https://github.com/zpratt/react-tdd-guide
guide howto javascript jest react tdd tutorial
Last synced: about 12 hours ago
JSON representation
A series of examples on how to TDD React
- Host: GitHub
- URL: https://github.com/zpratt/react-tdd-guide
- Owner: zpratt
- License: mit
- Created: 2015-04-19T16:17:19.000Z (over 9 years ago)
- Default Branch: main
- Last Pushed: 2023-01-07T07:53:20.000Z (about 2 years ago)
- Last Synced: 2025-01-04T09:56:47.568Z (8 days ago)
- Topics: guide, howto, javascript, jest, react, tdd, tutorial
- Language: JavaScript
- Homepage:
- Size: 571 KB
- Stars: 597
- Watchers: 15
- Forks: 34
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-tdd - React TDD guide - A series of examples on how to TDD React by Zach Pratt. (React.js / Guides React)
README
# react-tdd-guide
A series of examples on how to TDD React## Getting started
1. install [nvm](https://github.com/creationix/nvm)
- Grab an editor or IDE. I recommend Webstorm, Atom, and VIM, in that order.
- `git clone` ...
- `nvm install 4` OR if v4 of node.js is installed, `nvm use`
- `npm i`## How to use this guide
Each section is broken out into its own folder, starting with [basics](https://github.com/zpratt/react-tdd-guide/tree/master/basics). What you'll find there is the finished example. I am experimenting with using the [commit history](https://github.com/zpratt/react-tdd-guide/commits/master/basics) and comments to drive the guide itself. Feedback on whether this works or not would be appreciated.
Each commit that is suffixed with **"- red"** can be checked out separately to examine the failing test. Each commit that is suffixed with **"- green"** shows how I finally passed the failing assertion.
Looking at the history for each section will show you only the steps needed to drive that part of the application.
## Philosophy
* Avoid the need for runners and browsers
* Achieved by using jest and [react-testing-library](https://testing-library.com/docs/react-testing-library/intro)## Table of Contents
* [Basics](https://github.com/zpratt/react-tdd-guide/commits/master/basics) - Steps for TDD'ing the simplest of React components: An unordered list of items. Start here if you're not familiar with TDD'ing React and want to see a simple introduction.
* [Running version](http://zpratt.github.io/react-tdd-guide/examples/basics/)
* [Simple event handling](https://github.com/zpratt/react-tdd-guide/commits/master/event-handling) (WIP)
* [Simple stateful input](https://github.com/zpratt/react-tdd-guide/commits/master/state)
* Centralized state management techniques (not done)
* Redux (not done)
* React router (not done)## Running the tests for a section
* `npm run `
## Running all tests
* `npm test`
## Contributing
Please feel free to open an issue for:
* A question on how to do something
* A request for further clarificationUse a pull request for
* Suggestions on changing how something is tested
* To add an example you think would be valuable## Caveats
I am not a windows user, therefore this has only been tested on OSX.