Skip to content

Commit

Permalink
fix: set copy_data_to_bin default to True to mitigate ESM loader issue
Browse files Browse the repository at this point in the history
  • Loading branch information
gregmagolan committed Aug 5, 2022
1 parent 20858e0 commit fa9c1e0
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 10 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ Known issues:
- Doesn't support Remote Execution (RBE) due to https://github.com/bazelbuild/bazel/issues/10298.
- Doesn't work with rules_docker due to https://github.com/bazelbuild/rules_pkg/issues/115#issuecomment-1137465914.
- No examples yet for publishing npm packages.
- ESM imports escape the runfiles tree and the sandbox due to https://github.com/aspect-build/rules_js/issues/362

rules_js is just a part of what Aspect provides:

Expand Down
2 changes: 0 additions & 2 deletions examples/macro/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,6 @@ npm_link_all_packages(name = "node_modules")
mocha_test(
name = "test",
srcs = ["test.js"],
# Work-around for mocha leaving the runfiles & sandbox
copy_data_to_bin = True,
)

bzl_library(
Expand Down
20 changes: 12 additions & 8 deletions js/private/js_binary.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -159,8 +159,10 @@ _ATTRS = {
"preserve_symlinks_main": attr.bool(
doc = """When True, the --preserve-symlinks-main flag is passed to node.
This prevents node from following entry script out of runfiles and the sandbox which can happen for some entry
files such as `.mjs` where the fs node patches, which guard the runfiles and sandbox, are not used.
This prevents node from following entry script out of runfiles and the sandbox which can happen for `.mjs` ESM
entry points where the fs node patches, which guard the runfiles and sandbox, are not applied.
See https://github.com/aspect-build/rules_js/issues/362 for more information. Once #362 is resolved,
the default for this attribute can be set to False.
This flag was added in Node.js v10.2.0 (released 2018-05-23). If your node toolchain is configured to use a
Node.js version older than this you'll need to set this attribute to False.
Expand All @@ -173,14 +175,16 @@ _ATTRS = {
doc = """When True, data files and the entry_point file are copied to the Bazel output tree before being passed
as inputs to runfiles.
This default to False. It should only be needed if the program manages to skirt the node fs patches and leave
its runfiles and/or sandbox. In that case, setting this to True will prevent the program from following symlinks
into the source tree and it will end up in the output tree instead where node_modules and other inputs the
program may need will be.
Ideally, the default for this would be False as it is optimal, but there is a yet unresloved issue of ESM imports
skirting the node fs patches and escaping the sandbox: https://github.com/aspect-build/rules_js/issues/362.
This is hit in some test popular runners such as mocha, which use native `import()` statements
(https://github.com/aspect-build/rules_js/pull/353).
Mocha, for example, has been observed to escape its runfiles & sandbox: https://github.com/aspect-build/rules_js/pull/353.
A default of True will prevent program such as mocha from following symlinks into the source tree. They will
escape the sandbox but they will end up in the output tree where node_modules and other inputs required will be
available. With this in mind, the default will remain true until issue #362 is resolved.
""",
default = False,
default = True,
),
"_launcher_template": attr.label(
default = Label("//js/private:js_binary.sh.tpl"),
Expand Down

0 comments on commit fa9c1e0

Please sign in to comment.