-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[code-infra] vitest
browser & jsdom modes
#14508
base: master
Are you sure you want to change the base?
Changes from all commits
8e375a2
3eced20
2893eef
4645e72
a8464a9
8f540d7
4507e81
90754d6
8218f0e
a9af3e4
6fffa88
2b0754e
23925ac
5c85b9f
f1269fd
3e2fbe4
164ec72
e396545
5121079
570e939
8812678
a06bb50
f3da275
7ba380b
ca22dde
ff6c715
90d0af7
db2817d
b2b8628
8434b41
0f8b218
2d5d395
4d58fb9
493133d
f338a12
66c410e
94b4443
43ce018
b219263
f530667
4fd6d33
8d3601c
23bb8c2
4497dd8
6539759
b20b1bb
840c4b6
6db68b8
9f6f828
a353cb6
1885222
f985554
b869545
739c2d4
8b38fd9
f5493b8
820bbd5
8342499
163ed7e
953059d
dac3923
ddc252d
8d28a7b
1d47d30
0e13811
88378a6
d32bfe5
dd40b0e
0bba870
f06ff48
5c57167
c264163
a1feb9b
3615198
8757aa4
9799824
ed6dbb8
7c62bfc
4f6b9c4
5442abd
aba0b63
5a930f1
8066b23
3bc1fa7
98013ae
f3b6d1f
7cf9c69
0098dbc
fa96d91
0085b9e
121bde4
dd2621b
fd39e32
a154440
10523ec
96d1d12
d86d6cf
9d486d6
3bfdce8
73b10fe
be83e61
1ff3ea1
1da790d
6a5056e
ee14aa5
9b4e396
1d38796
0bfd396
4788163
ff510c2
e5859c4
0ac9091
10d594d
ed4e45c
8143ff0
6145ec0
6137a65
2501941
0daad6b
ab3517c
399898f
ff30d99
9af685b
2750a58
9d49f6d
bc93279
b8d1d31
d3a6684
5058664
6a85d6f
dcb21c0
de5877b
c881448
20d745c
8edef9d
7e62e43
efd2e32
149bf34
69c594c
441b4ec
db141ec
3498128
d1bf2d4
9d8828a
f411f01
ebc3172
c9ad767
58681e0
4f9cc56
e040b42
25fafe2
71bf483
825d24f
43fea96
bdff27a
ff2846f
5a9c982
0b0a0c3
4797a30
d1c9d7e
dc988a6
608d851
d66936e
4438aa1
093f61e
8707b71
8302086
393db84
1b08251
5e2e9c0
73df0e5
ba2e15a
49010a8
70272b7
d265568
5cbc098
924da97
d0f94cd
f7fa812
c98fd74
f125aab
b8868bb
2364ccf
6f15cae
6408abe
c440d24
e38c84e
cdeda36
451c335
982e939
e1e0ea9
0c04687
d1984a5
15a057e
ed81020
e54ed0a
b2c73f5
56c8f7e
81a2390
5b86840
0030cf7
d796401
d742e1a
87bf972
73c5bb0
4440524
4ab09dc
6f4194b
fbe8f10
5a1bb97
4e628db
ece6211
fbb59e5
c1caef1
d7db870
ee7522c
eb4fa2d
ed68a3d
cc7def7
e431909
8783db0
4e0a70f
dba0d1a
4a217e9
e1222d0
c4590d2
e4e290a
5140d87
717884e
36397bb
c26eba7
51279df
2f5f809
944e2b1
7c42626
367629a
e803e18
ff58b72
1b05f5a
61919e2
f6ef256
d57a049
94c1fcd
314a9cc
f370f89
3fbb79d
406bf75
f05cd7f
f11f3df
85df890
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
name: Vitest | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. CircleCI please: https://www.notion.so/mui-org/code-infra-Migrate-out-of-CircleCI-42350363b7344380a9961cf9731aae31 for the final version of this effort. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, this is just for ensuring the changes work while working on them There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can we remove the GH workflow given that CircleCI is already setup? 🤔 |
||
|
||
on: | ||
push: | ||
branches: | ||
- 'master' | ||
- 'next' | ||
pull_request: | ||
branches: | ||
- 'master' | ||
- 'next' | ||
|
||
permissions: {} | ||
|
||
jobs: | ||
vitest-jsdom: | ||
name: Vitest Tests (jsdom) | ||
runs-on: ubuntu-latest | ||
timeout-minutes: 20 | ||
steps: | ||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||
- uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||
with: | ||
run_install: false | ||
- name: Use Node.js 20.x | ||
uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||
with: | ||
node-version: 20 | ||
cache: 'pnpm' # https://github.com/actions/setup-node/blob/main/docs/advanced-usage.md#caching-packages-dependencies | ||
- run: pnpm install --frozen-lockfile | ||
- name: Install Playwright Browsers | ||
run: pnpm playwright install --with-deps | ||
- name: Run Tests | ||
run: pnpm vitest --project "jsdom/*" --coverage | ||
vitest-browser: | ||
name: Vitest Tests (browser) | ||
runs-on: ubuntu-latest | ||
timeout-minutes: 20 | ||
steps: | ||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||
- uses: pnpm/action-setup@fe02b34f77f8bc703788d5817da081398fad5dd2 # v4.0.0 | ||
with: | ||
run_install: false | ||
- name: Use Node.js 20.x | ||
uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4.0.3 | ||
with: | ||
node-version: 20 | ||
cache: 'pnpm' # https://github.com/actions/setup-node/blob/main/docs/advanced-usage.md#caching-packages-dependencies | ||
- run: pnpm install --frozen-lockfile | ||
- name: Install Playwright Browsers | ||
run: pnpm playwright install --with-deps | ||
- name: Run Tests | ||
run: pnpm vitest --project "browser/*" |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import { mergeConfig, defineProject } from 'vitest/config'; | ||
import sharedConfig from '../vitest.shared.mts'; | ||
import packageJson from './package.json'; | ||
|
||
export default mergeConfig( | ||
sharedConfig, | ||
defineProject({ | ||
test: { | ||
name: `jsdom/${packageJson.name.split('/')[1]}`, | ||
environment: 'jsdom', | ||
}, | ||
}), | ||
); |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -66,7 +66,8 @@ | |
"release:publish:dry-run": "pnpm publish --recursive --tag next --registry=\"http://localhost:4873/\"", | ||
"release:tag": "node scripts/releaseTag.mjs", | ||
"validate": "concurrently \"pnpm prettier && pnpm eslint\" \"pnpm proptypes\" \"pnpm docs:typescript:formatted\" \"pnpm docs:api\"", | ||
"clean:node_modules": "rimraf --glob \"**/node_modules\"" | ||
"clean:node_modules": "rimraf --glob \"**/node_modules\"", | ||
"vitest": "cross-env TZ=UTC vitest" | ||
}, | ||
"devDependencies": { | ||
"@actions/core": "^1.11.1", | ||
|
@@ -101,9 +102,10 @@ | |
"@octokit/plugin-retry": "^7.1.3", | ||
"@octokit/rest": "^21.1.0", | ||
"@playwright/test": "^1.49.1", | ||
"@testing-library/dom": "^10.4.0", | ||
"@testing-library/react": "^16.0.1", | ||
"@types/babel__core": "^7.20.5", | ||
"@types/babel__traverse": "^7.20.6", | ||
"@types/chai": "^4.3.20", | ||
"@types/chai-dom": "^1.11.3", | ||
"@types/fs-extra": "^11.0.4", | ||
"@types/karma": "^6.3.9", | ||
|
@@ -117,6 +119,9 @@ | |
"@types/yargs": "^17.0.33", | ||
"@typescript-eslint/eslint-plugin": "^7.18.0", | ||
"@typescript-eslint/parser": "^7.18.0", | ||
"@vitejs/plugin-react": "^4.3.2", | ||
"@vitest/browser": "^2.1.8", | ||
"@vitest/coverage-istanbul": "^2.1.8", | ||
"autoprefixer": "^10.4.20", | ||
"axe-core": "4.10.2", | ||
"babel-loader": "^9.2.1", | ||
|
@@ -191,14 +196,21 @@ | |
"typescript": "^5.7.3", | ||
"unist-util-visit": "^5.0.0", | ||
"util": "^0.12.5", | ||
"vite-plugin-filter-replace": "^0.1.14", | ||
"vitest": "2.1.8", | ||
"vitest-fail-on-console": "^0.7.1", | ||
"webpack": "^5.97.1", | ||
"webpack-bundle-analyzer": "^4.10.2", | ||
"webpack-cli": "^6.0.1", | ||
"yargs": "^17.7.2" | ||
}, | ||
"resolutions": { | ||
"react-is": "^19.0.0", | ||
"@types/node": "^20.17.12" | ||
"@types/node": "^20.17.12", | ||
"@playwright/test": "1.49.1", | ||
"playwright": "1.49.1", | ||
"@vitest/browser>playwright": "1.49.1", | ||
"@mui/internal-test-utils>playwright": "1.49.1" | ||
}, | ||
"packageManager": "[email protected]", | ||
"engines": { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
import { mergeConfig, defineProject } from 'vitest/config'; | ||
import sharedConfig from '../../vitest.shared.mts'; | ||
import packageJson from './package.json'; | ||
|
||
export default mergeConfig( | ||
sharedConfig, | ||
defineProject({ | ||
test: { | ||
name: `browser/${packageJson.name.split('/')[1]}`, | ||
browser: { | ||
enabled: true, | ||
name: 'chromium', | ||
provider: 'playwright', | ||
headless: true, | ||
screenshotFailures: false, | ||
}, | ||
}, | ||
}), | ||
); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import { mergeConfig, defineProject } from 'vitest/config'; | ||
import sharedConfig from '../../vitest.shared.mts'; | ||
import packageJson from './package.json'; | ||
|
||
export default mergeConfig( | ||
sharedConfig, | ||
defineProject({ | ||
test: { | ||
name: `jsdom/${packageJson.name.split('/')[1]}`, | ||
environment: 'jsdom', | ||
}, | ||
}), | ||
); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
import { mergeConfig, defineProject } from 'vitest/config'; | ||
import sharedConfig from '../../vitest.shared.mts'; | ||
import packageJson from './package.json'; | ||
|
||
export default mergeConfig( | ||
sharedConfig, | ||
defineProject({ | ||
test: { | ||
name: `browser/${packageJson.name.split('/')[1]}`, | ||
browser: { | ||
enabled: true, | ||
name: 'chromium', | ||
provider: 'playwright', | ||
headless: true, | ||
screenshotFailures: false, | ||
}, | ||
}, | ||
}), | ||
); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import { mergeConfig, defineProject } from 'vitest/config'; | ||
import sharedConfig from '../../vitest.shared.mts'; | ||
import packageJson from './package.json'; | ||
|
||
export default mergeConfig( | ||
sharedConfig, | ||
defineProject({ | ||
test: { | ||
name: `jsdom/${packageJson.name.split('/')[1]}`, | ||
environment: 'jsdom', | ||
}, | ||
}), | ||
); |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -27,14 +27,25 @@ const config = { | |
describe('BarChart - click event', () => { | ||
const { render } = createRenderer(); | ||
|
||
beforeEach(() => { | ||
if (window?.document?.body?.style) { | ||
window.document.body.style.margin = '0'; | ||
} | ||
}); | ||
|
||
afterEach(() => { | ||
if (window?.document?.body?.style) { | ||
window.document.body.style.margin = '8px'; | ||
} | ||
}); | ||
Comment on lines
+30
to
+40
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Some charts tests are reliant screen position, and margins are different for karma and vitest, so we force one. 🙃 |
||
|
||
describe('onAxisClick', () => { | ||
// can't do Pointer event with JSDom https://github.com/jsdom/jsdom/issues/2527 | ||
testSkipIf(isJSDOM)('should provide the right context as second argument', () => { | ||
const onAxisClick = spy(); | ||
render( | ||
<div | ||
style={{ | ||
margin: -8, // Removes the body default margins | ||
width: 400, | ||
height: 400, | ||
}} | ||
|
@@ -85,7 +96,6 @@ describe('BarChart - click event', () => { | |
render( | ||
<div | ||
style={{ | ||
margin: -8, // Removes the body default margins | ||
width: 400, | ||
height: 400, | ||
}} | ||
|
@@ -157,7 +167,6 @@ describe('BarChart - click event', () => { | |
render( | ||
<div | ||
style={{ | ||
margin: -8, // No idea why, but that make the SVG coordinates match the HTML coordinates | ||
width: 400, | ||
height: 400, | ||
}} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
With this regex, it seems hard to search in the codebase for, e.g.
.tsx
, I suspect that listing all the permutations would be clearer.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't see why you would need to search for that though. As you will have to sweep over all configuration files when doing a change that would require updating that anyways 😅
Replacing it to list all the permutations is quite unnecessary in my view:
{.ts,.tsx,.js,.cjs,.cjsx,.mjs,.mjsx,.cts,.ctsx,.mts,.mtsx}
We could cleanup some unlikely exts like
{.ts,.tsx,.js,.cjs,.mjs,.mts}
which would be simpler, but less complete.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could it actually be great? I assume we will never need those other extensions, so if someone create them, he might be more likely to realize those are wrong?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Quite the contrary, we sometimes need those extensions:
tsx
), we need a way to signal node which module system is being used.next/document
in ESM.esbuild
,tsx
andvitest
rely on the extension to determine whether JSX needs to be transformed or not. This is currently giving problems as we have a bunch of jsx in.js
files. See Enable JSX in.js
files privatenumber/tsx#644 and Allow JSX in .js files vitest-dev/vitest#1564. For the latter I have a workaround but it also forces our.ts
files to adhere to the JSX rules, which required me to refactor some code.We shouldn't restrict extensions, they're not for cosmetic reasons. We should just prefer
.ts
/.tsx
unless specific runtime requirements demand otherwise.Besides that, I think the logic of "so if someone create them, he might be more likely to realize those are wrong?" is flawed. They likely won't realize anything, starting with not realizing eslint is not running on their code 😄. Better is to apply the rules to any file that could contain javascript/typescript and if we need to enforce a specific extension we should use a specific rule for that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Janpot If a developer can't run the tests he/she try to write in dev mode, I think he/she will notice that something is off.
For eslint specifically, yeah, agree, the ideal is to lint the file and have an eslint rule that error because the extension is wrong.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In any case, why have them waste time reverse engineering the tests to find out they're using the wrong extension if the eslint plugin can tell them in context in the editor? 🤔 Not that there would be anything wrong with using .jsx instead of .js for JSX files, contrary, it would kind of make things easier.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍 https://www.npmjs.com/package/eslint-plugin-filename-rules sounds great.
I think that the value of only having
.js
is about not having to think about extensions. Having to rename a file after refactoring its content and moving the code around is friction to change.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But we can't get around this friction in typescript. Finishing the typescript migration means imposing this friction across the codebase anyway.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🙂 Coincidentally, I'm just running into a problem that illustrates why this is harmful. Just trying to figure out why I have a failing test locally in vitest that doesn't seem to break in mocha. The following produces a failing test:
But when you try running the global command:
Whoops, no test is running. What happened? Somewhere along the way we started running the build script natively in node. The file was renamed to .mjs. The test runner only looks for .js, .ts, and .tsx. The author didn't see any tests break after running them and assumed they were good. They didn't realize the test stopped running altogether. If the test framework was configured to run on any encountered javascript file, nothing would have been broken.
It took me a while to realize the test wasn't running, my first instinct was "something fails in vitest that breaks in mocha".