-
Notifications
You must be signed in to change notification settings - Fork 30.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
src,worker: add isInternalWorker #56469
src,worker: add isInternalWorker #56469
Conversation
Might close nodejs/import-in-the-middle/issues/38 |
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.
Nicely done!
Maaaybe for consistency with isMainThread
, the name should actually be isInternalThread
(sorry, I was the one who originally told said isInternalWorker
).
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #56469 +/- ##
==========================================
- Coverage 88.53% 88.52% -0.02%
==========================================
Files 657 660 +3
Lines 190761 190898 +137
Branches 36616 36626 +10
==========================================
+ Hits 168899 168996 +97
- Misses 15048 15089 +41
+ Partials 6814 6813 -1
|
Co-authored-by: Jacob Smith <3012099+JakobJingleheimer@users.noreply.github.com>
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.
nearly there! 🙌
Co-authored-by: Jacob Smith <3012099+JakobJingleheimer@users.noreply.github.com>
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.
LGTM 😁 hopefully @bengl can confirm it does what he needs.
Can we move this forward? @JakobJingleheimer |
It's all good from my perspective. But Bryan would be the one to verify that it suits the need. I think I saw from him somewhere that he's been quite overwhelmed recently, which kinda means this is stuck unless we can find someone else who can verify it. |
@jsumners-nr, I think this is related to what you do IRL. Is this something you can say will or won't meet the needs of APMs? |
Right now, what I can say is that I recall several discussions around this sort of feature in loader and/or diagnostics conversations. I cannot recall where those discussions are, or really who was participating. I think @Qard was participating and had specific ideas about how this would be useful, but I'm not 100% sure of that. In my personal APM work, I haven't seen a need to know that it is a new thread. We just, don't deal with threads. I'm not clear how this would solve the linked IITM issue. That issue seems rooted in ESM (like most of the issues holding that project down). In short, this seems like a fair feature. But I don't have enough knowledge to provide the information you're looking for. |
The TLDR context was that APMs need a way to know whether they're running inside the loader worker. I can't recall why they need to know that. |
Yeah, me either 😢 |
That should be sufficient. Basically was just needed to logic-branch what was loaded from the library depending on if it's loaded in the app thread or the loader thread. We couldn't identify a loader thread by looking at the workerData object. (At least not reliably as the contents were unspecified.) I'm not at Datadog anymore so might still want to poke @bengl to verify there's nothing else, but as far as I recall that was it. |
Awesome, thank you! |
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.
LGTM, does what I need it to.
Landed in 732744c |
Thanks everyone! |
PR-URL: #56469 Reviewed-By: Jacob Smith <jacob@frende.me> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Bryan English <bryan@bryanenglish.com>
This PR adds an
isInternalWorker
tonode:worker_threads
similar toisMainThread
but to detect if the thread is an instance ofInternalWorker