-
-
Notifications
You must be signed in to change notification settings - Fork 6.5k
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
Getting an Namespace 'NodeJS' has no exported member 'Global' error #11640
Comments
We just came across this too when our CI builds started failing. Looks like Managed to work around it by adding |
|
hello, I have a problem with it |
Can a maintainer please provide an update on this? This is causing ecosystem-wide disruption. I've documented only a few instances here. Someone has graciously provided a fix here yet official maintainers have been silent. Also, what is being done to ensure that this does not occur again in the future? |
Also experiencing this issue. |
If this issue isn't addressed by tomorrow I will work on adding a a small compatibility layer to v16, the preferred approach however is for people to to stick to v15 for now. |
Just hit this as well after upgrading to jest 27 from jest 26 |
I worked around this by adding "@types/[email protected]" as a dependency. I hope this helps someone until the issue is resolved. :) |
@fouchekeagan yep that's exactly how we fixed it, if you are on node types @16 it won't work thanks for sharing |
- I've been to hell and back, and haven't managed to pinpoint all of the exact dependencies that cause the build to leak (or more likely: attempt to over-allocate) memory but after extensive testing, this is the set of dependencies that manages to build in an environment with max 3GB of memory available - It could very well be that some of the dependencies blocked by this commit's locks simply take the build's memory consumption over the 3GB limit and aren't part of the same issue of over allocating memory -- but this is a decent compromise that ensures that the build should no longer intermittently fail in CI (which has 4GB, of which roughly 3,3GB is usable) - The test setup: - `docker run --rm -it --volume $(pwd):/home/circleci/project --memory=3G cimg/node:14.15` (same image as in CI, and 3 GB of memory ensures that the build will always work on the 4 GB available in CI) 1. `cd .. && cp -r project frontend` (just to ignore any file permission issues without touching the executor image too much) 2. `rm -rf dist node_modules` 3. `yarn install --immutable` 4. `yarn build` 5. -> repeat at least 3 times and if all pass (& CI passes) -> OK set of dependency versions - 8 parallel CI jobs running to increase sample size with `/sys/fs/cgroup/memory/memory.max_usage_in_bytes` logged - Findings: - _Something_ (or a combination of things) attempts to over allocate memory (specifically new heap space) when running with `master`'s versions of frontend dependencies (likely culprits described below) - With the versions used in this commit, the build will use all memory available to it but GC is early enough to never actually go over the limit **but** something in the newer dependencies goes over the line, causing reaping of the build processes and crashing the build - The most likely explanation would be something "outside" the Node.js process (i.e. something creates additional processes), which doesn't obey the same heap limits - TypeScript 4.3 has a few issues with relating to complex types which lead to at least significantly higher memory usage (likely not the same over-allocation issue as below) -> **lock to ~4.2.x** - Related: microsoft/TypeScript#44299 and microsoft/TypeScript#44281 - This is actually a good idea anyway as TS makes breaking changes in "minor" releases (e.g. 4.2.x -> 4.3.x) and we shouldn't blindly update it - webpack's dependency `[email protected]` updates `jest-worker` 26 -> 27 which appears to cause memory over allocation, likely related to the way it creates new processes and/or threads for workers based on incorrect assumptions about the available amount of CPU cores inside a Docker container (`os.cpus()` vs. what's actually allocated in cgroups) -> **lock to 5.1.1** - There's also a big issue with shared dependencies with `@storybook/*` modules also using webpack (but *4.x.x* instead of 5.x.x), which makes using `resolutions` pretty difficult without locking absolutely everything - Related: webpack/webpack#13550 and webpack-contrib/terser-webpack-plugin#403 - `@types/[email protected]` is incompatible with Jest 27 (jestjs/jest#11640) -> update only to 15.x.x - `[email protected]` updates _some_ dependency that either causes a similar memory over-allocation or simply increases the build's memory usage over the set 3GB limit - My money's on `webpack-sources` as based on webpack's changelogs it appears to have had some memory leak issues between the versions used by `[email protected]` and `[email protected]` (latest at the time of this commit) - `[email protected]` could also be related but didn't manage to find anything conclusive here - Additionally, update all dependencies _that don't break the build / cause memory issues_ to the latest non-major versions - Excluded Chart.js (& related) dependencies as that whole repo seems in a very weird place now - 3.x.x released a while ago and there hasn't been any release notes, tags or anything - 3.0.0 diff is pretty massive with very non-descriptive commit/PR messages - Excluded `react-select` and `react-datepicker` as they're going to be dropped at some point and both of them appeared to have pretty major changes - Excluded Testcafe as that's always a pain & we're going to drop it when everything's been re-written for Playwright - Update webpack loaders to their latest (incl. major) versions -- nothing breaking for us
NodeJS.Global is exported in five places: jest-fake-timers: legacyFakeTimers.ts But there are quite a few more in the tests.
Edit: I tried upgrading jest to node 16 types but got stuck (1) because of other node 16 changes (2) the difference between places that accept either globals or Window, or require both globals and Window. |
@SimonSchick How'd you do it? |
|
@SimonSchick I may have misunderstood. The fix has been shipped? I was only able to make this work by installing @types/[email protected]. I've read the relevant typescript docs many times and tried many, many permutations (https://www.typescriptlang.org/docs/handbook/declaration-files/templates/global-d-ts.html). I want to type this: // file.ts
global.thing = {
logging: new Logger(),
version: version
} This is the original global.d.ts, which works in @types/node@15: // global.d.ts
declare global {
module NodeJS {
interface Global {
thing: {
logging: Logger,
version: string
}
}
}
} With @types/node@16 I get the following error: Things I've tried:
I've been at this for a few hours now and I just can't figure it out. I mean @types/node@15 works and so does: |
All global MUST be declared w/ declare global {
var myGlobal: number;
} Please read the documentation |
I feel like we might have gotten a bit sidetracked, so looping back around to the original error: @SimonSchick you said previously:
Did you end up doing this? I can't see any strong evidence that you did, and for me type checking is still broken using the latest v16 types, but wanted to double check in case I'd missed something. I've been able to resolve the problem locally with the following:
Which should suffice as a temporary workaround to allow compiling & typechecking in downstream projects. |
I had to do the following to get mine to work, as I'm building a custom reporter and preset. // https://github.com/facebook/jest/issues/11640#issuecomment-893867514
declare global {
namespace NodeJS {
interface Global {}
interface InspectOptions {}
interface ConsoleConstructor
extends console.ConsoleConstructor {}
}
} |
The `playwright` repo uses `expect`, I'd like to bump the version they're using from `26.4.2` to `27.1.0`. Here is the issue which motivated this change: jestjs#11640 You can see my proposed changes here: microsoft/playwright@master...mrienstra:patch-3 I haven't opened a PR for those changes yet, hoping to land this one first. Playwright `npm check-deps` runs `utils/check_deps.js`, which contains a function `allowExternalImport` / `alllowExternalImport` (very recently added in microsoft/playwright#8501), which has a problem with the `expect` `package.json` `exports`, thus the motivation for this PR.
This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs. |
🐛 Bug Report
When trying to build our solution we get the following error:
Namespace 'NodeJS' has no exported member 'Global' on line node_modules/@jest/types/build/Global.d.ts:85:62
Seems to be coming from https://github.com/facebook/jest/blob/master/packages/jest-types/src/Global.ts line 137
To Reproduce
Version of node 14.16.1 & Jest 27.0.6
Expected behavior
Not to get this error when building
Link to repl or repo (highly encouraged)
https://github.com/robgeurden/easy-test
The text was updated successfully, but these errors were encountered: