Interested in contributing to React DevTools, but not sure where to start? This is the place!# Install project dependenciesTo get started, check out the React repo:```sh
git clone [email protected]:facebook/react.git```Next install dependencies:```sh
cd <react-repo>yarn install```# Build React and React DOMNext, check out (or build) the local version of React that DevTools uses:### Option 1 (fastest): Checkout pre-built ReactTo check out the latest version of React (built by CI from the `main` branch) run:
```sh
cd <react-repo>cd scripts/releaseyarn install./download-experimental-build.js --commit=main```### Option 2: Build from sourceIf your DevTools change includes local changes to React (or if CI is down for some reason) you can also build from source:```sh
cd <react-repo>yarn build-for-devtools```# Testing your changes### Option 1 (fastest): Using the test shellMost changes can be tested using the DevTools test app. To run this, you'll need two terminals:First, run DevTools in DEV mode:```sh
cd <react-repo>cd packages/react-devtools-inlineyarn start```Next, run the test shell:```sh
cd <react-repo>cd packages/react-devtools-shellyarn start```Now any changes you make to DevTools will automatically reload in the test app at http://localhost:8080### Option 2: Using the extensionSome changes requiring testing in the browser extension (e.g. like "named hooks"). To do this, run the following script:```sh
cd <react-repo>cd packages/react-devtools-extensionsyarn build:chrome:local && yarn test:chrome```This will launch a standalone version of Chrome with the locally built React DevTools pre-installed. If you are testing a specific URL, you can make your testing even faster by passing the `--url` argument to the test script:
```sh
yarn build:chrome && yarn test:chrome --url=<url-to-test>```# Unit testsCore DevTools functionality is typically unit tested (see [here](https://github.com/facebook/react/tree/main/packages/react-devtools-shared/src/__tests__)). To run tests, you'll first need to build or download React and React DOM ([as explained above](#build-react-and-react-dom)) and then use the following NPM script:
```sh
yarn test-build-devtools```You can connect tests to a debugger as well if you'd like by running:```sh
yarn debug-test-build-devtools```# Finding the right first issueThe React team maintains [this list of "good first issues"](https://github.com/facebook/react/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%22Component%3A+Developer+Tools%22+label%3A%22good+first+issue%22) for anyone interested in contributing to DevTools. If you see one that interests you, leave a comment!
If you have ideas or suggestions of your own, you can also put together a PR demonstrating them. We suggest filing an issue before making any substantial changes though, to ensure that the idea is something the team feels comfortable landing.