Skip to content

Commit

Permalink
fix(@angular-devkit/build-angular): only set ngDevMode when script op…
Browse files Browse the repository at this point in the history
…timizations are enabled

When using the experimental esbuild-based browser application builder, the `ngDevMode` global
runtime variable was unintentionally always being set to false due to a previous bug fix that stopped
the variable from being replaced with the value of true when script optimizations were disabled.
By doing so, the fix caused the imported compiler-cli `GLOBAL_DEFS_FOR_TERSER_WITH_AOT` constant
to take precedence which contains an `ngDevMode` value of false. To prevent this situation for
development builds where a non-false `ngDevMode` is helpful to surface potential runtime problems,
`GLOBAL_DEFS_FOR_TERSER_WITH_AOT` will no longer change the value of `ngDevMode`. This fix does not
have any effect on production builds since `ngDevMode` would have been set to false regardless.

(cherry picked from commit 310144d)
  • Loading branch information
clydin committed Dec 13, 2022
1 parent ccc8e03 commit 9fd3562
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -192,6 +192,10 @@ export function createCompilerPlugin(
// Skip keys that have been manually provided
continue;
}
if (key === 'ngDevMode') {
// ngDevMode is already set based on the builder's script optimization option
continue;
}
// esbuild requires values to be a string (actual strings need to be quoted).
// In this case, all provided values are booleans.
build.initialOptions.define[key] = value.toString();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -296,7 +296,11 @@ function createCodeBundleOptions(
),
],
define: {
// Only set to false when script optimizations are enabled. It should not be set to true because
// Angular turns `ngDevMode` into an object for development debugging purposes when not defined
// which a constant true value would break.
...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),
// Only AOT mode is supported currently
'ngJitMode': 'false',
},
};
Expand Down

0 comments on commit 9fd3562

Please # to comment.