commit | 843341ce9778d17908224668218d603203ae5589 | [log] [tgz] |
---|---|---|
author | Hiroshige Hayashizaki <hiroshige@chromium.org> | Thu Sep 24 11:39:57 2020 |
committer | Commit Bot <commit-bot@chromium.org> | Thu Sep 24 11:39:57 2020 |
tree | 2f6c3e460841e9373e81bcccb98efa0a19d788a2 | |
parent | c1a7d15acb2eaa7773929ca992a6c53120305bd3 [diff] |
Consider module script evaluation with an exception as a failure Previously, when an exception is thrown, ModulatorImplBase::ExecuteModule() returns ModuleEvaluationResult::Empty(), when CaptureEvalErrorFlag::kReport is used and top-level await is not enabled. This is considered as success, but this is inconsistent with - ModuleRecord::Evaluate() that returns ModuleEvaluationResult::FromException() (that is considered as non-success), and - Classic script evaluation. This CL makes ModulatorImplBase::ExecuteModule() return ModuleEvaluationResult with an exception in such cases. Behavior change: This changes WorkerReportingProxy::DidEvaluateTopLevelScript()'s |is_success| value from true to false when a module script have parse/evaluation/etc. errors. This makes serviceworker registration fails for such scripts, fixing crbug.com/1129795. This CL fixes content/test/data/service_worker/worker.js to use `globalThis` instead of `this`, because on module scripts `this` can't be used to get the global object. (Previously, the test using this script ServiceWorkerVersionBrowserTest.StartInstalledModuleScriptWhileOffline unexpectedly threw an exception during evaluation of `worker.js` as a module service worker top-level script, but didn't fail due to this issue) Bug: 1129795, 1129743, 1111134 Change-Id: I5443539c201e1ab220fd17f9291b307432853450 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2419054 Commit-Queue: Hiroshige Hayashizaki <hiroshige@chromium.org> Reviewed-by: Hiroki Nakagawa <nhiroki@chromium.org> Reviewed-by: Matt Falkenhagen <falken@chromium.org> Reviewed-by: Dominic Farolino <dom@chromium.org> Cr-Commit-Position: refs/heads/master@{#810141}
Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all users to experience the web.
The project's web site is https://www.chromium.org.
Documentation in the source is rooted in docs/README.md.
Learn how to Get Around the Chromium Source Code Directory Structure .
For historical reasons, there are some small top level directories. Now the guidance is that new top level directories are for product (e.g. Chrome, Android WebView, Ash). Even if these products have multiple executables, the code should be in subdirectories of the product.