-
-
Notifications
You must be signed in to change notification settings - Fork 59
Debugging Tips
The tips are focused on debugging and troubleshooting in VSCode with the PowerShell extension. They are not limited to this PowerShell host and environment. But VSCode is quite powerful and easily available.
Open your build script in the editor and set the required breakpoints by F9.
Currently, VSCode editor breakpoints are not always synchronised with the PowerShell breakpoints. To work around this, hit F5 as if you are about to debug a build script directly. This fails with an error like "The term 'task' is not recognized..." but makes breakpoints ready.
Invoke your build scenario in VSCode normally, i.e. type a build command in the integrated PowerShell console or simply invoke the current task from the build script in the editor, see Invoke Task from VSCode.
As a result, you break into the debugger when breakpoints are hit during the build. Use the VSCode debugger as usual, i.e. explore the variables and call stack or type commands in the integrated console.
Use the little handy script Debug-Error.ps1 in order to break into the debugger on terminating errors automatically. See its help for the details.
It is recommended to limit the scope of errors to the scripts of interest, i.e. the build script. That is, use the command
Debug-Error MyProject.build.ps1
in order to enable stops exactly in MyProject.build.ps1 and skip related noise stops in the build engine. Errors are caught and re-thrown several times in the engine code and you do not want to stop there on each.
Invoke-Build scripts are usual PowerShell code and the standard PowerShell
debugging tools are available. You can set some interesting breakpoints by
Set-PSBreakpoint
.
To break when a function is called
Set-PSBreakpoint -Command MyBuildFunction
To break when a variable is read or written
Set-PSBreakpoint -Variable MyBuildVariable [-Mode Read | Write | ReadWrite]
- Concepts
- Script Tutorial
- Incremental Tasks
- Partial Incremental Tasks
- How Build Works
- Special Variables
- Build Failures
- Build Analysis
- Parallel Builds
- Persistent Builds
- Portable Build Scripts
- Using for Test Automation
- Debugging Tips
- VSCode Tips
Helpers
- Invoke Task from VSCode
- Generate VSCode Tasks
- Invoke Task from ISE
- Resolve MSBuild
- Show Build Trees
- Show Build Graph
- Argument Completers
- Invoke-Build.template
Appendix