2018-02-19 18:09:38 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Application Debugging
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Whenever your Electron application is not behaving the way you wanted it to,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								an array of debugging tools might help you find coding errors, performance
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bottlenecks, or optimization opportunities.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Renderer Process
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-02-21 10:12:19 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The most comprehensive tool to debug individual renderer processes is the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Chromium Developer Toolset. It is available for all renderer processes,
							 
						 
					
						
							
								
									
										
										
										
											2018-02-19 18:09:38 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								including instances of `BrowserWindow` , `BrowserView` , and `WebView` . You
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								can open them programmatically by calling the `openDevTools()`  API on the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`webContents`  of the instance: 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-20 23:50:08 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2018-02-19 18:09:38 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								const { BrowserWindow } = require('electron')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-09 10:18:49 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const win = new BrowserWindow()
							 
						 
					
						
							
								
									
										
										
										
											2018-02-19 18:09:38 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								win.webContents.openDevTools()
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Google offers [excellent documentation for their developer tools][devtools].
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								We recommend that you make yourself familiar with them - they are usually one
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								of the most powerful utilities in any Electron Developer's tool belt.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Main Process
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-08 00:16:09 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Debugging the main process is a bit trickier, since you cannot open
							 
						 
					
						
							
								
									
										
										
										
											2024-05-28 11:15:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								developer tools for them. The Chromium Developer Tools can
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[be used to debug Electron's main process][node-inspect] thanks to a closer collaboration
							 
						 
					
						
							
								
									
										
										
										
											2018-02-19 18:09:38 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								between Google / Chrome and Node.js, but you might encounter oddities like
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`require`  not being present in the console. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For more information, see the [Debugging the Main Process documentation][main-debug].
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[node-inspect]: https://nodejs.org/en/docs/inspector/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[devtools]: https://developer.chrome.com/devtools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[main-debug]: ./debugging-main-process.md
							 
						 
					
						
							
								
									
										
										
										
											2020-03-18 13:02:01 +10:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## V8 Crashes
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If the V8 context crashes, the DevTools will display this message.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`DevTools was disconnected from the page. Once page is reloaded, DevTools will automatically reconnect.`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-23 18:02:16 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Chromium logs can be enabled via the `ELECTRON_ENABLE_LOGGING`  environment variable. For more information, see the [environment variables documentation ](../api/environment-variables.md#electron_enable_logging ).
							 
						 
					
						
							
								
									
										
										
										
											2020-03-18 13:02:01 +10:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:17:25 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Alternatively, the command line argument `--enable-logging`  can be passed. More information is available in the [command line switches documentation ](../api/command-line-switches.md#--enable-loggingfile ).