From b5cbb445585a3f1cf85b40a8535fe7105cfbab8a Mon Sep 17 00:00:00 2001 From: Alex Eagle Date: Sun, 9 Jan 2022 06:13:06 -0800 Subject: [PATCH] chore: code review feedback for #3195 --- examples/vendored_node_and_yarn/package.json | 2 + internal/npm_install/npm_install.bzl | 51 ++++++++++---------- 2 files changed, 28 insertions(+), 25 deletions(-) diff --git a/examples/vendored_node_and_yarn/package.json b/examples/vendored_node_and_yarn/package.json index 8457261c29..4bfc0e3906 100644 --- a/examples/vendored_node_and_yarn/package.json +++ b/examples/vendored_node_and_yarn/package.json @@ -5,6 +5,8 @@ "jasmine": "^3.5.0" }, "scripts": { + "//": "assert that yarn version is the one we vendored", + "postinstall": "node -e \"require('assert').equal('yarn/1.10.0', process.env['npm_config_user_agent'].split(' ').find(x => x.startsWith('yarn/')))\"", "test": "bazel test ..." } } diff --git a/internal/npm_install/npm_install.bzl b/internal/npm_install/npm_install.bzl index 7fa46f3dd2..608d2ce16c 100644 --- a/internal/npm_install/npm_install.bzl +++ b/internal/npm_install/npm_install.bzl @@ -805,6 +805,15 @@ check if yarn is being run by the `npm_install` repository rule.""", implementation = _npm_install_impl, ) +def _detect_yarn_version(rctx, yarn): + result = rctx.execute([rctx.path(yarn), "--version"]) + if result.return_code: + fail("yarn --version failed: %s (%s)" % (result.stdout, result.stderr)) + if result.stdout.startswith("1."): + return "classic" + + return "berry" + def _yarn_install_impl(repository_ctx): """Core implementation of yarn_install.""" @@ -813,18 +822,7 @@ def _yarn_install_impl(repository_ctx): is_windows_host = is_windows_os(repository_ctx) node = repository_ctx.path(get_node_label(repository_ctx)) yarn = get_yarn_label(repository_ctx) - result = repository_ctx.execute( - [repository_ctx.path(yarn), "--version"], - timeout = repository_ctx.attr.timeout, - quiet = repository_ctx.attr.quiet, - ) - if result.return_code: - fail("yarn --version failed: %s (%s)" % (result.stdout, result.stderr)) - if result.stdout.startswith("1."): - yarn_version = "classic" - else: - yarn_version = "berry" - + yarn_version = _detect_yarn_version(repository_ctx, yarn) yarn_args = [] # Set frozen lockfile as default install to install the exact version from the yarn.lock @@ -836,20 +834,20 @@ def _yarn_install_impl(repository_ctx): else: fail("--frozen-lockfile should not be used with yarn 2+. Just pass arguments like --immutable.") - if not repository_ctx.attr.use_global_yarn_cache: - yarn_args.extend(["--cache-folder", str(repository_ctx.path("_yarn_cache"))]) - elif yarn_version == "classic": - # Multiple yarn rules cannot run simultaneously using a shared cache. - # See https://github.com/yarnpkg/yarn/issues/683 - # The --mutex option ensures only one yarn runs at a time, see - # https://yarnpkg.com/en/docs/cli#toc-concurrency-and-mutex - # The shared cache is not necessarily hermetic, but we need to cache downloaded - # artifacts somewhere, so we rely on yarn to be correct. - yarn_args.extend(["--mutex", "network"]) + if repository_ctx.attr.use_global_yarn_cache: + # According to maintainers, the yarn cache is now atomic in berry, so this flag is only needed in classic. + # See https://github.com/bazelbuild/rules_nodejs/pull/3195#discussion_r780719932 + if yarn_version == "classic": + # Multiple yarn rules cannot run simultaneously using a shared cache. + # See https://github.com/yarnpkg/yarn/issues/683 + # The --mutex option ensures only one yarn runs at a time, see + # https://yarnpkg.com/en/docs/cli#toc-concurrency-and-mutex + # The shared cache is not necessarily hermetic, but we need to cache downloaded + # artifacts somewhere, so we rely on yarn to be correct. + yarn_args.extend(["--mutex", "network"]) else: - # Can't tell from documentation if Yarn Berry has any replacement for the --mutex - # flag. We'll have to assume it's safe to run concurrently. - pass + yarn_args.extend(["--cache-folder", str(repository_ctx.path("_yarn_cache"))]) + yarn_args.extend(repository_ctx.attr.args) # Run the package manager in the package.json folder @@ -957,6 +955,9 @@ yarn_install = repository_rule( See yarn CLI docs for complete list of supported arguments. Yarn 1: https://yarnpkg.com/en/docs/cli/install Yarn 2+ (Berry): https://yarnpkg.com/cli/install + +Note that Yarn Berry PnP is *not* supported, follow +https://github.com/bazelbuild/rules_nodejs/issues/1599 """, default = [], ),