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}
5 files changed
tree: 2f6c3e460841e9373e81bcccb98efa0a19d788a2
  1. android_webview/
  2. apps/
  3. ash/
  4. base/
  5. build/
  6. build_overrides/
  7. buildtools/
  8. cc/
  9. chrome/
  10. chromecast/
  11. chromeos/
  12. cloud_print/
  13. components/
  14. content/
  15. courgette/
  16. crypto/
  17. dbus/
  18. device/
  19. docs/
  20. extensions/
  21. fuchsia/
  22. gin/
  23. google_apis/
  24. google_update/
  25. gpu/
  26. headless/
  27. infra/
  28. ios/
  29. ipc/
  30. jingle/
  31. media/
  32. mojo/
  33. native_client_sdk/
  34. net/
  35. pdf/
  36. ppapi/
  37. printing/
  38. remoting/
  39. rlz/
  40. sandbox/
  41. services/
  42. skia/
  43. sql/
  44. storage/
  45. styleguide/
  46. testing/
  47. third_party/
  48. tools/
  49. ui/
  50. url/
  51. weblayer/
  52. .clang-format
  53. .clang-tidy
  54. .eslintrc.js
  55. .git-blame-ignore-revs
  56. .gitattributes
  57. .gitignore
  58. .gn
  59. .vpython
  60. .vpython3
  61. .yapfignore
  62. AUTHORS
  63. BUILD.gn
  64. CODE_OF_CONDUCT.md
  65. codereview.settings
  66. DEPS
  67. DIR_METADATA
  68. ENG_REVIEW_OWNERS
  69. LICENSE
  70. LICENSE.chromium_os
  71. OWNERS
  72. PRESUBMIT.py
  73. PRESUBMIT_test.py
  74. PRESUBMIT_test_mocks.py
  75. README.md
  76. WATCHLISTS
README.md

Logo Chromium

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.