node_cache: Run pnpm install if node_modules not present in help-beta.

We need this check when switching between branches without `help-beta`
package. `node_modules` will be removed when working on a non `help-beta`
branch, but if `node_modules/.pnpm/lock.yaml` has not been updated by that
branch, we will end up in a situation where we might not have `node_modules`
even when we run the provision command.

We might not need this check when the `help-beta` initial folder
has been merged for a week or two, where almost all active PRs
would have been rebased upon main, making switching branches an ease.
This commit is contained in:
Shubham Padia 2024-06-25 17:21:45 +00:00 committed by Tim Abbott
parent dfc426a057
commit d7889221db
1 changed files with 22 additions and 11 deletions

View File

@ -9,13 +9,24 @@ def setup_node_modules(production: bool = DEFAULT_PRODUCTION) -> None:
if os.path.islink("node_modules"): if os.path.islink("node_modules"):
os.unlink("node_modules") os.unlink("node_modules")
skip = False
try: try:
with open("node_modules/.pnpm/lock.yaml") as a, open("pnpm-lock.yaml") as b: with open("node_modules/.pnpm/lock.yaml") as a, open("pnpm-lock.yaml") as b:
if a.read() == b.read(): if a.read() == b.read():
return skip = True
except FileNotFoundError: except FileNotFoundError:
pass pass
# We need this check when switching between branches without `help-beta`
# package. `node_modules` will be removed when working on a non `help-beta`
# branch, but if `node_modules/.pnpm/lock.yaml` has not been updated by that
# branch, we will end up in a situation where we might not have `node_modules`
# even when we run the provision command.
if not os.path.exists("help-beta/node_modules"):
skip = False
if not skip:
run( run(
[ [
"/usr/local/bin/corepack", "/usr/local/bin/corepack",