This repository contains a couple of demos for core debugging stories, that need to be supported by DevTools to provide a fundamental, seamless debugging experience.
Demo projects and repros should be pushed to ChromeDevTools/devtools-dbg-stories, and will then automatically be available on devtools-dbg-stories.netlify.app.
When creating a repro for a crbug, the recommended workflow is as follows:
-
Create your own fork on GitHub.
-
Check out the fork locally.
git clone git@github.com:user/devtools-dbg-stories.git git remote add upstream https://github.com/ChromeDevTools/devtools-dbg-stories.git
and create a feature branch.
-
Follow the steps for simple test cases.
npm install npm start
This will serve the examples at http://localhost:8000.
-
Create a new file
src/crbug-ID.html
(and other resources that are necessary), whereID
refers to the bug number, and add a link to thecrbug-ID.html
file to thesrc/index.html
. -
Once you are happy with your repro, push it to your fork and send a pull request to the main repository.
The following projects have been adapted from todomvc.com.
What to check: Open the debugger and the console, observe whether breakpoints, the object inspector, the watch expressions, call stacks etc. all work as well as they would when debugging vanilla JS code.
cd typescript-react
npm install
npm start
The server will be running at http://localhost:1234.
cd typescript-angular
npm install
npm run compile
python -m SimpleHTTPServer
The server will be running at http://localhost:8000.
cd typescript-backbone
npm install
npm run compile
open index.html
This is an example project following the starter template for Learn Next.js.
What to check: Open the debugger, search for index.js and other authored files in the Page tree and Quick Open panel.
What is shown: Intertwining of authored and deployed sources.
cd nextjs-webpack
npm install
npm run build
npm run dev
The server will be running at http://localhost:3000.
This is an example project following the guides from webpack.js.org/guides/hot-module-replacement.
What to check: Open the debugger, click the button on the page, and make some changes to second.js
in your favorite editor.
What is shown: HMR will update the page and also add a duplicated script in the Page tree and Quick Open panel.
To run the stock webpack server with HMR:
cd webpack-basic-hmr
npm install
npm run webpack-serve
Or, to use a custom express server with HMR middleware:
npm run express-serve
The server will be running at http://localhost:8080.
What to check (not in sequence):
- Open the Performance panel, start recording, scroll down. Observe the unnecessary yellow background color changing on the number of comments.
- Open the Performance panel, start recording, click on a news to toggle the details (slide in and out). Observe the animation.
What is shown: Animation, long task, paint reflow. This codelab will walk you through the issues and how to fix them: https://developers.google.com/web/fundamentals/codelabs/web-perf
How to run it:
- Get the code: [https://github.com/googlearchive/udacity-60fps-samples]
- To run it, use any local server, e.g. http-server.
What to check: Open the performance panel, start recording, and click on the "+" button on the page. Observe the long tasks.
What is shown: A performance issue in a long task which stems from some expensive computation. There is something that takes a long time (is "hot"), and usually occurs once but it can also happen multiple times. E.g. processing large amounts of data with an inappropriate algorithm on the main thread.
cd react-redux-bad-algo
npm install
npm start
The server will be running at http://localhost:3000.
What to check: Open the performance panel, start recording, and click on the "+" button on the page. Observe the long tasks.
What is shown: A performance issue in a long task which stems from the broad app architecture, rather than a singular expensive computation. There is something that is inexpensive, but dominates by occurring repeatedly many times. Usually the solution involves having to rethink the execution model. E.g. in case of react+redux, having to compute many selectors for each state change to determine which views must update, in views which would not have to update.
cd react-redux-bad-arch
npm install
npm start
The server will be running at http://localhost:3000.
Clone this repository, and run
npm install
npm start
afterwards point your browser to http://localhost:8000.