Skip to content
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

Fix console.log(globalThis) crash #3175 #3267

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

EngoDev
Copy link

@EngoDev EngoDev commented Dec 24, 2024

The bug in #3175 is caused by the fact that the function getGPU in global_scope.c++ is set to only work in a DurableObject, and that is not the case in local development.

The fix is simple: Instead of setting the wgpu flag to be always on, enable it only in CI.
As long as wgpu is meant to be only accessible in DureableObjects, this fix should suffice.

I hope I didn't miss anything, and I'm happy to iterate on it otherwise.

Output of the Bazel run all tests (dbg) task:
image

Output of bazel test --config=cli -c dbg --cache_test_results=no //...:
image

@EngoDev EngoDev requested review from a team as code owners December 24, 2024 03:28
@EngoDev EngoDev requested review from jp4a50 and mar-cf December 24, 2024 03:28
Copy link

github-actions bot commented Dec 24, 2024

All contributors have signed the CLA ✍️ ✅
Posted by the CLA Assistant Lite bot.

@EngoDev EngoDev changed the title Fix console.log(gloabThis) crash #3175 Fix console.log(globalThis) crash #3175 Dec 24, 2024
@EngoDev
Copy link
Author

EngoDev commented Dec 24, 2024

I have read the CLA Document and I hereby sign the CLA

github-actions bot added a commit that referenced this pull request Dec 24, 2024
@mar-cf mar-cf requested a review from anonrig December 24, 2024 09:03
@fhanau
Copy link
Collaborator

fhanau commented Dec 24, 2024

Not enabling webGPU in local development would resolve the error message, but just not building a feature is never just a simple bug fix. If we disable webGPU, it would need to be a deliberate decision and communicated properly.
CC @anonrig can we think of a more narrow workaround?

@anonrig
Copy link
Member

anonrig commented Dec 24, 2024

I think the correct approach is basically not throw an error when webgpu attribute is accessed and just return undefined.

@EngoDev EngoDev force-pushed the engodev/fix-globalThis-webgpu-error branch from a658206 to f8742aa Compare December 24, 2024 18:36
@EngoDev
Copy link
Author

EngoDev commented Dec 24, 2024

Not enabling webGPU in local development would resolve the error message, but just not building a feature is never just a simple bug fix. If we disable webGPU, it would need to be a deliberate decision and communicated properly. CC @anonrig can we think of a more narrow workaround?

My thought process with this approach was that because it's already implicit in the code that you can't run any wgpu code outside of a DurableObject, so disabling this feature for local development doesn't practically take any functionality away from it but I understand what you are saying, and It makes sense.

This felt like a trivial change, so I filled a PR for it per the CONTRIBUTING.md file; I didn't mean to overstep.

I think the correct approach is basically not throw an error when webgpu attribute is accessed and just return undefined.

Following your suggestion, I changed getGPU to return an Optional but I'm not sure about the logging for the function, I think it would be helpful to keep the messages as warning logs, should I use LOG_WARNING_PERIODICALLY or LOG_WARNING_ONCE?

@EngoDev EngoDev force-pushed the engodev/fix-globalThis-webgpu-error branch 3 times, most recently from 71d0113 to 99487f5 Compare December 24, 2024 18:59
@anonrig
Copy link
Member

anonrig commented Dec 24, 2024

I think we should not log a warning. Anybody can console.log, in any part of the project (including dependencies). We should treat this case as "webgpu is not implemented".

@EngoDev EngoDev force-pushed the engodev/fix-globalThis-webgpu-error branch from 99487f5 to 79c839b Compare December 24, 2024 22:11
@EngoDev
Copy link
Author

EngoDev commented Dec 24, 2024

I think we should not log a warning. Anybody can console.log, in any part of the project (including dependencies). We should treat this case as "webgpu is not implemented".

That's a good point, I removed the logs.

@anonrig
Copy link
Member

anonrig commented Dec 25, 2024

Can you also add a test case where we call console.log?

@EngoDev EngoDev force-pushed the engodev/fix-globalThis-webgpu-error branch 2 times, most recently from cf646f3 to b88340a Compare December 25, 2024 15:30
@EngoDev
Copy link
Author

EngoDev commented Dec 25, 2024

Can you also add a test case where we call console.log?

Yes, of course. I added a test to inspect globalThis. Using console.log in the test, results in the error not being caught because it's not being bubbled up to the test so I call util.inspect directly on globalThis.

One thing that I noticed while testing the test function is that the error is being propagated twice (And the second error seems to have a very long stack from the same file). I lack context on the product overall, but I found this weird, so I thought I would mention it just in case it is something.

workerd/server/server.c++:4336: debug: [ TEST ] global-scope-test:validateGlobalThis
workerd/io/worker.c++:2082: info: uncaught exception; source = Uncaught; stack = AssertionError [ERR_ASSERTION]: Got unwanted exception: globalThis shouldn't fail to be inspected.
Actual message: "Error: TypeError: webgpu api is only available in Durable Objects
    at Navigator.formatJsgResourceType (node-internal:internal_inspect:2383:31)
    at formatValue (node-internal:internal_inspect:813:49)
    at formatProperty (node-internal:internal_inspect:1875:15)
    at formatRaw (node-internal:internal_inspect:1081:25)
    at formatValue (node-internal:internal_inspect:841:12)
    at inspect (node-internal:internal_inspect:397:12)
    at formatJsgResourceType (node-internal:internal_inspect:2402:23)
    at formatValue (node-internal:internal_inspect:813:49)
    at formatProperty (node-internal:internal_inspect:1875:15)
    at formatRaw (node-internal:internal_inspect:1081:25)
    at assert.fail (node-internal:internal_inspect:43:11)
    at handleMaxCallStackSize (node-internal:internal_inspect:1516:12)
    at formatRaw (node-internal:internal_inspect:1089:16)
    at formatValue (node-internal:internal_inspect:841:12)
    at inspect (node-internal:internal_inspect:397:12)
    at formatJsgResourceType (node-internal:internal_inspect:2402:23)
    at formatValue (node-internal:internal_inspect:813:49)
    at formatProperty (node-internal:internal_inspect:1875:15)
    at formatRaw (node-internal:internal_inspect:1081:25)
    at formatValue (node-internal:internal_inspect:841:12)"
    at new AssertionError (node-internal:internal_assertionerror:427:15)
    at gotUnwantedException (node-internal:internal_assert:412:15)
    at doesNotThrow (node-internal:internal_assert:153:9)
    at Object.test (worker:752:5)
kj/exception.c++:357: warning: llvm-symbolizer was not found. To symbolize stack traces, install it in your $PATH or set $LLVM_SYMBOLIZER to the location of the binary. When running tests under bazel, use `--test_env=LLVM_SYMBOLIZER=<path>`.
workerd/io/io-context.c++:355: info: uncaught exception; exception = workerd/jsg/_virtual_includes/jsg/workerd/jsg/value.h:1372: failed: jsg.Error: AssertionError: Got unwanted exception: globalThis shouldn't fail to be inspected.
Actual message: "Error: TypeError: webgpu api is only available in Durable Objects
    at Navigator.formatJsgResourceType (node-internal:internal_inspect:2383:31)
    at formatValue (node-internal:internal_inspect:813:49)
    at formatProperty (node-internal:internal_inspect:1875:15)
    at formatRaw (node-internal:internal_inspect:1081:25)
    at formatValue (node-internal:internal_inspect:841:12)
    at inspect (node-internal:internal_inspect:397:12)
    at formatJsgResourceType (node-internal:internal_inspect:2402:23)
    at formatValue (node-internal:internal_inspect:813:49)
    at formatProperty (node-internal:internal_inspect:1875:15)
    at formatRaw (node-internal:internal_inspect:1081:25)
    at assert.fail (node-internal:internal_inspect:43:11)
    at handleMaxCallStackSize (node-internal:internal_inspect:1516:12)
    at formatRaw (node-internal:internal_inspect:1089:16)
    at formatValue (node-internal:internal_inspect:841:12)
    at inspect (node-internal:internal_inspect:397:12)
    at formatJsgResourceType (node-internal:internal_inspect:2402:23)
    at formatValue (node-internal:internal_inspect:813:49)
    at formatProperty (node-internal:internal_inspect:1875:15)
    at formatRaw (node-internal:internal_inspect:1081:25)
    at formatValue (node-internal:internal_inspect:841:12)"
stack: src/workerd/server/workerd@6383ce9 src/workerd/server/workerd@4c30fec src/workerd/server/workerd@4c30a70 src/workerd/server/workerd@4c1a4c1 src/workerd/server/workerd@4c1a3db src/workerd/server/workerd@4c1a188 src/workerd/server/workerd@4c19b49 src/workerd/server/workerd@4c19493 src/workerd/server/workerd@4c19220 src/workerd/server/workerd@4c1919b src/workerd/server/workerd@4c19174 src/workerd/server/workerd@4c11431 src/workerd/server/workerd@4c11033 src/workerd/server/workerd@4c08031 src/workerd/server/workerd@4be6cdc src/workerd/server/workerd@4be7cb0 src/workerd/server/workerd@4be7aac src/workerd/server/workerd@a7ad7f0 src/workerd/server/workerd@a794bcc src/workerd/server/workerd@a794adb src/workerd/server/workerd@a79624d src/workerd/server/workerd@a796da3 src/workerd/server/workerd@a7905bb src/workerd/server/workerd@a7acf49 src/workerd/server/workerd@a792da5 src/workerd/server/workerd@a79287a src/workerd/server/workerd@3e9c58e src/workerd/server/workerd@3e9b6b2 src/workerd/server/workerd@3e9b0e1 src/workerd/server/workerd@3e9b098 src/workerd/server/workerd@3e9b06e
workerd/server/server.c++:4344: debug: [ FAIL ] global-scope-test:validateGlobalThis


export const validateGlobalThis = {
test() {
doesNotThrow(
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Using doesNotThrow(...) is a bit unnecessary. Just calling util.inspect(globalThis) should be fine here as if the inspection throws the test will fail.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed doesNotThrow

@EngoDev EngoDev force-pushed the engodev/fix-globalThis-webgpu-error branch from b88340a to 8415734 Compare January 2, 2025 22:38
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants