Skip to content

Commit 16232c8

Browse files
authored
chore: add support for caching node_modules within a nested repository (#12862)
This PR removes a hack added in #12760 This fixes an issue where we were querying the root git repository for hashes for files which are only tracked in the `noir/noir-repo` repository. We now set the `REPO_PATH` env variable so that we run `git ls-tree` on the correct repository.
1 parent 6efc8ce commit 16232c8

File tree

7 files changed

+31
-25
lines changed

7 files changed

+31
-25
lines changed

bootstrap.sh

+2
Original file line numberDiff line numberDiff line change
@@ -177,6 +177,8 @@ function test {
177177
function build {
178178
echo_header "pull submodules"
179179
denoise "git submodule update --init --recursive"
180+
echo_header "sync noir repo"
181+
export NOIR_HASH=$(./noir/bootstrap.sh hash)
180182

181183
check_toolchains
182184

ci3/npm_install_deps

+7-2
Original file line numberDiff line numberDiff line change
@@ -3,14 +3,19 @@
33
# Note this cache pull won't restore .yarn, which means a subsequent "yarn install" may still be slow.
44
# This doesn't matter in CI however.
55
NO_CD=1 source ${root:-$(git rev-parse --show-toplevel)}/ci3/source
6+
# We assume that `yarn.lock` sits within the root directory of the git repository we're currently in.
7+
#
8+
# We cannot assume that this is equal to `$root` as we may be within a nested repository
9+
# whereas `$root` points to the root of the aztec-packages monorepo.
10+
REPO_PATH=$(git rev-parse --show-toplevel)
611

712
if [ ! -f yarn.lock ]; then
813
echo_stderr "yarn.lock not found in $PWD."
914
exit 1
1015
fi
1116

12-
yarn_lock_path=$(realpath yarn.lock --relative-to=$root)
13-
package_json_path=$(realpath package.json --relative-to=$root)
17+
yarn_lock_path=$(realpath yarn.lock --relative-to=$REPO_PATH)
18+
package_json_path=$(realpath package.json --relative-to=$REPO_PATH)
1419

1520
if [ "$CI" -eq 1 ]; then
1621
nm_hash=$(cache_content_hash "^$yarn_lock_path" "^$package_json_path")

noir-projects/aztec-nr/bootstrap.sh

+2-1
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,8 @@ cmd=${1:-}
66
export RAYON_NUM_THREADS=${RAYON_NUM_THREADS:-16}
77
export HARDWARE_CONCURRENCY=${HARDWARE_CONCURRENCY:-16}
88
export NARGO=${NARGO:-../../noir/noir-repo/target/release/nargo}
9-
hash=$(hash_str $(../../noir/bootstrap.sh hash) $(cache_content_hash "^noir-projects/aztec-nr"))
9+
export NOIR_HASH=${NOIR_HASH:- $(../../noir/bootstrap.sh hash)}
10+
hash=$(hash_str "$NOIR_HASH" $(cache_content_hash "^noir-projects/aztec-nr"))
1011

1112
function build {
1213
# Being a library, aztec-nr does not technically need to be built. But we can still run nargo check to find any type

noir-projects/bootstrap.sh

+2
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,8 @@ source $(git rev-parse --show-toplevel)/ci3/source_bootstrap
33

44
cmd=${1:-}
55

6+
export NOIR_HASH=${NOIR_HASH-$(../noir/bootstrap.sh hash)}
7+
68
function build {
79
echo_header "noir-projects build"
810

noir-projects/noir-contracts/bootstrap.sh

+2-1
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,7 @@ export BB=${BB:-../../barretenberg/cpp/build/bin/bb}
2727
export NARGO=${NARGO:-../../noir/noir-repo/target/release/nargo}
2828
export TRANSPILER=${TRANSPILER:-../../avm-transpiler/target/release/avm-transpiler}
2929
export BB_HASH=$(cache_content_hash ../../barretenberg/cpp/.rebuild_patterns)
30+
export NOIR_HASH=${NOIR_HASH:-$(../../noir/bootstrap.sh hash)}
3031

3132
export tmp_dir=./target/tmp
3233

@@ -98,7 +99,7 @@ export -f process_function
9899
# Compute hash for a given contract.
99100
function get_contract_hash {
100101
hash_str \
101-
$(../../noir/bootstrap.sh hash) \
102+
$NOIR_HASH \
102103
$(cache_content_hash \
103104
../../avm-transpiler/.rebuild_patterns \
104105
"^noir-projects/noir-contracts/contracts/$1/" \

noir-projects/noir-protocol-circuits/bootstrap.sh

+5-5
Original file line numberDiff line numberDiff line change
@@ -12,16 +12,16 @@ export PLATFORM_TAG=any
1212
export BB=${BB:-../../barretenberg/cpp/build/bin/bb}
1313
export NARGO=${NARGO:-../../noir/noir-repo/target/release/nargo}
1414
export BB_HASH=$(cache_content_hash ../../barretenberg/cpp/.rebuild_patterns)
15-
export NARGO_HASH=$(../../noir/bootstrap.sh hash)
15+
export NOIR_HASH=${NOIR_HASH:-$(../../noir/bootstrap.sh hash)}
1616

17-
test_flag=$project_name-tests-$(hash_str "$NARGO_HASH" $(cache_content_hash "^noir-projects/$project_name"))
17+
test_flag=$project_name-tests-$(hash_str "$NOIR_HASH" $(cache_content_hash "^noir-projects/$project_name"))
1818
key_dir=./target/keys
1919
mkdir -p $key_dir
2020

2121
# Hash of the entire protocol circuits.
2222
# Needed for test hash, as we presently don't have a program hash for each individual test.
2323
# Means if anything within the dir changes, the tests will rerun.
24-
circuits_hash=$(hash_str "$NARGO_HASH" $(cache_content_hash "^noir-projects/$project_name/crates/"))
24+
circuits_hash=$(hash_str "$NOIR_HASH" $(cache_content_hash "^noir-projects/$project_name/crates/"))
2525

2626
# Circuits matching these patterns we have client-ivc keys computed, rather than ultra-honk.
2727
ivc_patterns=(
@@ -68,8 +68,8 @@ function compile {
6868
local program_hash_cmd="$NARGO check --package $name --silence-warnings --show-program-hash | cut -d' ' -f2"
6969
# echo_stderr $program_hash_cmd
7070
program_hash=$(dump_fail "$program_hash_cmd")
71-
echo_stderr "Hash preimage: $NARGO_HASH-$program_hash"
72-
hash=$(hash_str "$NARGO_HASH-$program_hash")
71+
echo_stderr "Hash preimage: $NOIR_HASH-$program_hash"
72+
hash=$(hash_str "$NOIR_HASH-$program_hash")
7373

7474
if ! cache_download circuit-$hash.tar.gz 1>&2; then
7575
SECONDS=0

noir/bootstrap.sh

+11-16
Original file line numberDiff line numberDiff line change
@@ -64,10 +64,16 @@ function noir_content_hash {
6464
fi
6565
}
6666

67+
if [ ! -v NOIR_HASH ]; then
68+
noir_sync
69+
export NOIR_HASH=$(noir_content_hash)
70+
fi
71+
72+
6773
# Builds nargo, acvm and profiler binaries.
6874
function build_native {
6975
set -euo pipefail
70-
local hash=$(noir_content_hash)
76+
local hash=$NOIR_HASH
7177
if cache_download noir-$hash.tar.gz; then
7278
return
7379
fi
@@ -83,23 +89,17 @@ function build_native {
8389
# Builds js packages.
8490
function build_packages {
8591
set -euo pipefail
86-
local hash=$(noir_content_hash)
92+
local hash=$NOIR_HASH
8793

8894
if cache_download noir-packages-$hash.tar.gz; then
8995
cd noir-repo
9096
npm_install_deps
91-
# Hack to get around failure introduced by https://github.com/AztecProtocol/aztec-packages/pull/12371
92-
# Tests fail with message "env: ‘mocha’: No such file or directory"
93-
yarn install
9497
return
9598
fi
9699

97100
cd noir-repo
98101
npm_install_deps
99102

100-
# Hack to get around failure introduced by https://github.com/AztecProtocol/aztec-packages/pull/12371
101-
# Tests fail with message "env: ‘mocha’: No such file or directory"
102-
yarn install
103103
yarn workspaces foreach -A --parallel --topological-dev --verbose $js_include run build
104104

105105
# We create a folder called packages, that contains each package as it would be published to npm, named correctly.
@@ -156,7 +156,7 @@ function test {
156156

157157
# Prints the commands to run tests, one line per test, prefixed with the appropriate content hash.
158158
function test_cmds {
159-
local test_hash=$(noir_content_hash 1)
159+
local test_hash=$NOIR_HASH
160160
cd noir-repo
161161
cargo nextest list --workspace --locked --release -Tjson-pretty 2>/dev/null | \
162162
jq -r '
@@ -231,25 +231,20 @@ case "$cmd" in
231231
git clean -ffdx
232232
;;
233233
"ci")
234-
noir_sync
235234
build
236235
test
237236
;;
238237
""|"fast"|"full")
239-
noir_sync
240238
build
241239
;;
242240
test_cmds|build_native|build_packages|format|test|release)
243-
noir_sync
244241
$cmd "$@"
245242
;;
246243
"hash")
247-
noir_sync
248-
echo $(noir_content_hash)
244+
echo $NOIR_HASH
249245
;;
250246
"hash-tests")
251-
noir_sync
252-
echo $(noir_content_hash 1)
247+
echo $NOIR_HASH
253248
;;
254249
"make-patch")
255250
scripts/sync.sh make-patch

0 commit comments

Comments
 (0)