Command
add
Is this a regression?
The previous version in which this bug was not present was
No response
Description
@angular/cli v21.2.0-next.0 added in f80db6f add ng-add support for Vitest browser providers but it is not complete and does not actually work.
The schematic correctly adds the required packages and modifies tsconfig.spec.json but does not add the browsers option as documented at https://angular.dev/guide/testing/migrating-to-vitest#5-configure-browser-mode-optional.
Without this option the test doesn't actually run in browser environment and is still run in DOM emulation library within Node.js.
Minimal Reproduction
Repro steps:
ng new angular22dot2dot0next0 --ssr=false --style=scss --ai-config=none
ng add @vitest/browser-playwright
npx playwright install
- Open
app.spec.ts and add line to any test: console.log('RUNNING IN:', navigator.userAgent);
- Run test via
ng test
- Observe the console outputs:
RUNNING IN: Mozilla/5.0 (win32) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/27.4.0
- Test still runs in Node.js with DOM emulation, not in Vitest browser ❌
How to fix:
- Open
angular.json and change:
"test": {
"builder": "@angular/build:unit-test"
}
to:
"test": {
"builder": "@angular/build:unit-test",
"options": {
"browsers": ["chromium"]
}
}
- Run test via
ng test
- Observe actual Chrome for Testing window opens and Console outputs:
RUNNING IN: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/145.0.0.0 Safari/537.36
- Test runs in Vitest browser 👍
Exception or Error
Your Environment
_ _ ____ _ ___
/ \ _ __ __ _ _ _| | __ _ _ __ / ___| | |_ _|
/ △ \ | '_ \ / _` | | | | |/ _` | '__| | | | | | |
/ ___ \| | | | (_| | |_| | | (_| | | | |___| |___ | |
/_/ \_\_| |_|\__, |\__,_|_|\__,_|_| \____|_____|___|
|___/
Angular CLI : 21.2.0-next.0
Node.js : 24.13.0
Package Manager : npm 11.6.2
Operating System : win32 x64
Anything else relevant?
No response
Command
add
Is this a regression?
The previous version in which this bug was not present was
No response
Description
@angular/cli v21.2.0-next.0 added in f80db6f
add ng-add support for Vitest browser providersbut it is not complete and does not actually work.The schematic correctly adds the required packages and modifies
tsconfig.spec.jsonbut does not add thebrowsersoption as documented at https://angular.dev/guide/testing/migrating-to-vitest#5-configure-browser-mode-optional.Without this option the test doesn't actually run in browser environment and is still run in DOM emulation library within Node.js.
Minimal Reproduction
Repro steps:
ng new angular22dot2dot0next0 --ssr=false --style=scss --ai-config=noneng add @vitest/browser-playwrightnpx playwright installapp.spec.tsand add line to any test:console.log('RUNNING IN:', navigator.userAgent);ng testRUNNING IN: Mozilla/5.0 (win32) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/27.4.0How to fix:
angular.jsonand change:to:
ng testRUNNING IN: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/145.0.0.0 Safari/537.36Exception or Error
Your Environment
Anything else relevant?
No response