From 20cc5fe6786bf60b2d7a90702ff482f15cde858b Mon Sep 17 00:00:00 2001 From: paolino Date: Mon, 15 Jul 2024 08:15:59 +0000 Subject: [PATCH 1/6] Add snapshot.sh script --- run/common/snapshot.sh | 40 +++++++++++++++++++++++++++++++++++++ run/preprod/nix/snapshot.sh | 1 + 2 files changed, 41 insertions(+) create mode 100755 run/common/snapshot.sh create mode 120000 run/preprod/nix/snapshot.sh diff --git a/run/common/snapshot.sh b/run/common/snapshot.sh new file mode 100755 index 00000000000..f5b9814a857 --- /dev/null +++ b/run/common/snapshot.sh @@ -0,0 +1,40 @@ +#! /usr/bin/env -S nix shell 'nixpkgs#curl' 'nixpkgs#lz4' 'nixpkgs#gnutar' --command bash +# shellcheck shell=bash + +set -euo pipefail + +# shellcheck disable=SC1091 +source .env + +# Define a local db if NODE_DB is not set +if [[ -z "${NODE_DB-}" ]]; then + LOCAL_NODE_DB=./databases/node-db + mkdir -p $LOCAL_NODE_DB + NODE_DB=$LOCAL_NODE_DB +fi + +# Clean the db directory +rm -rf "${NODE_DB:?}"/* + +echo "Network: $NETWORK" + +case "$NETWORK" in + preprod) + SNAPSHOT_NAME=$(curl -s https://downloads.csnapshots.io/testnet/testnet-db-snapshot.json| jq -r .[].file_name ) + echo "Snapshot name: $SNAPSHOT_NAME" + SNAPSHOT_URL="https://downloads.csnapshots.io/testnet/$SNAPSHOT_NAME" + ;; + *) + echo "Error: Invalid network $NETWORK" + exit 1 + ;; +esac + +echo "Downloading the snapshot..." + +curl -SL "$SNAPSHOT_URL" | lz4 -c -d - | tar -x -C "$NODE_DB" + +mv -f "$NODE_DB"/db/* "$NODE_DB"/ +rm -rf "$NODE_DB"/db + +echo "Snapshot downloaded and extracted to $NODE_DB" diff --git a/run/preprod/nix/snapshot.sh b/run/preprod/nix/snapshot.sh new file mode 120000 index 00000000000..ce506a7c77e --- /dev/null +++ b/run/preprod/nix/snapshot.sh @@ -0,0 +1 @@ +../../common/snapshot.sh \ No newline at end of file From 7442f2c7274449b52cf5b928cb77fbe52e8475c2 Mon Sep 17 00:00:00 2001 From: paolino Date: Sat, 13 Jul 2024 09:02:54 +0000 Subject: [PATCH 2/6] Add preprod scripts with docker --- run/preprod/docker/.env | 1 + run/preprod/docker/configs | 1 + run/preprod/docker/docker-compose.yml | 1 + run/preprod/docker/run.sh | 1 + run/preprod/docker/snapshot.sh | 1 + 5 files changed, 5 insertions(+) create mode 100644 run/preprod/docker/.env create mode 120000 run/preprod/docker/configs create mode 120000 run/preprod/docker/docker-compose.yml create mode 120000 run/preprod/docker/run.sh create mode 120000 run/preprod/docker/snapshot.sh diff --git a/run/preprod/docker/.env b/run/preprod/docker/.env new file mode 100644 index 00000000000..d7f8e0be46c --- /dev/null +++ b/run/preprod/docker/.env @@ -0,0 +1 @@ +NETWORK="preprod" \ No newline at end of file diff --git a/run/preprod/docker/configs b/run/preprod/docker/configs new file mode 120000 index 00000000000..0456cd8e3d5 --- /dev/null +++ b/run/preprod/docker/configs @@ -0,0 +1 @@ +../../../configs/cardano/preprod/ \ No newline at end of file diff --git a/run/preprod/docker/docker-compose.yml b/run/preprod/docker/docker-compose.yml new file mode 120000 index 00000000000..c984ebb6b07 --- /dev/null +++ b/run/preprod/docker/docker-compose.yml @@ -0,0 +1 @@ +../../common/docker/docker-compose.yml \ No newline at end of file diff --git a/run/preprod/docker/run.sh b/run/preprod/docker/run.sh new file mode 120000 index 00000000000..917564fe878 --- /dev/null +++ b/run/preprod/docker/run.sh @@ -0,0 +1 @@ +../../common/docker/run.sh \ No newline at end of file diff --git a/run/preprod/docker/snapshot.sh b/run/preprod/docker/snapshot.sh new file mode 120000 index 00000000000..ce506a7c77e --- /dev/null +++ b/run/preprod/docker/snapshot.sh @@ -0,0 +1 @@ +../../common/snapshot.sh \ No newline at end of file From 12307dbcb5501173a6a8cdd1153a65dfe46e3c9f Mon Sep 17 00:00:00 2001 From: paolino Date: Sat, 13 Jul 2024 11:29:48 +0000 Subject: [PATCH 3/6] Add docker full sync E2E test for preprod --- .buildkite/pipeline.yml | 42 ++++++++++++++++++++++++++++++++--------- run/preprod/docker/.env | 2 +- 2 files changed, 34 insertions(+), 10 deletions(-) diff --git a/.buildkite/pipeline.yml b/.buildkite/pipeline.yml index cb143c9322d..acc67b84cc8 100644 --- a/.buildkite/pipeline.yml +++ b/.buildkite/pipeline.yml @@ -523,13 +523,27 @@ steps: concurrency: 1 concurrency_group: 'docker' + - label: Private Network Full Sync + depends_on: + - docker-build + timeout: 20 + command: | + rm -rf run/private/docker/databases + cd run/private/docker && ./run.sh sync + artifact_paths: + - "./run/private/docker/logs/*" + agents: + system: x86_64-linux + concurrency: 1 + concurrency_group: 'docker' + - block: Sanchonet Full Sync if: build.env("RELEASE_CANDIDATE") == null - depends_on: docker-build + depends_on: + - docker-build key: docker-sanchonet-full-sync-block - label: Sanchonet Full Sync - key: docker-smoke-test-full-sync depends_on: - docker-sanchonet-full-sync-block timeout_in_minutes: 240 @@ -539,18 +553,28 @@ steps: artifact_paths: - "./run/sanchonet/docker/logs/*" agents: - system: x85_64-linux + system: x86_64-linux concurrency: 1 concurrency_group: 'docker' - - label: Private Network Full Sync - depends_on: docker-build - timeout: 20 + - block: Preprod Full Sync + if: build.env("RELEASE_CANDIDATE") == null + depends_on: + - docker-build + key: docker-preprod-full-sync-block + + - label: Preprod Full Sync + depends_on: + - docker-preprod-full-sync-block + timeout_in_minutes: 240 command: | - rm -rf run/private/docker/databases - cd run/private/docker && ./run.sh sync + rm -rf run/preprod/docker/databases + cd run/preprod/docker + # necessary to avoid the broken network + ./snapshot.sh + ./run.sh sync artifact_paths: - - "./run/private/docker/logs/*" + - "./run/preprod/docker/logs/*" agents: system: x86_64-linux concurrency: 1 diff --git a/run/preprod/docker/.env b/run/preprod/docker/.env index d7f8e0be46c..cb68696ae98 100644 --- a/run/preprod/docker/.env +++ b/run/preprod/docker/.env @@ -1 +1 @@ -NETWORK="preprod" \ No newline at end of file +NETWORK="preprod" From fc5bdef8b95690d12e29c8da99c52f152e0e8218 Mon Sep 17 00:00:00 2001 From: paolino Date: Sun, 14 Jul 2024 15:53:18 +0000 Subject: [PATCH 4/6] Add nix full sync E2E test for preprod --- .buildkite/pipeline.yml | 40 +++++++++++++++++++++++++++++++++------- run/preprod/nix/.env | 1 + run/preprod/nix/configs | 1 + run/preprod/nix/run.sh | 1 + 4 files changed, 36 insertions(+), 7 deletions(-) create mode 100644 run/preprod/nix/.env create mode 120000 run/preprod/nix/configs create mode 120000 run/preprod/nix/run.sh diff --git a/.buildkite/pipeline.yml b/.buildkite/pipeline.yml index acc67b84cc8..d012ebd9fd2 100644 --- a/.buildkite/pipeline.yml +++ b/.buildkite/pipeline.yml @@ -143,6 +143,22 @@ steps: concurrency: 1 concurrency_group: 'linux-e2e-tests' + - label: Private Network Full Sync + depends_on: linux-nix + timeout: 20 + command: | + rm -rf run/private/nix/logs + mkdir -p run/private/nix/logs + rm -rf run/private/nix/databases + cd run/private/nix && ./run.sh sync + artifact_paths: + - "./run/private/nix/logs/*" + agents: + system: x86_64-linux + env: + NODE_LOGS_FILE: ./logs/node.log + WALLET_LOGS_FILE: ./logs/wallet.log + - block: Sanchonet Full Sync if: build.env("RELEASE_CANDIDATE") == null depends_on: linux-nix @@ -166,22 +182,32 @@ steps: NODE_LOGS_FILE: ./logs/node.log WALLET_LOGS_FILE: ./logs/wallet.log - - label: Private Network Full Sync + - block: Preprod Full Sync + if: build.env("RELEASE_CANDIDATE") == null depends_on: linux-nix - timeout: 20 + key: linux-preprod-full-sync-block + + - label: Preprod Full Sync + depends_on: + - linux-nix + - linux-preprod-full-sync-block + timeout_in_minutes: 240 command: | - rm -rf run/private/nix/logs - mkdir -p run/private/nix/logs - rm -rf run/private/nix/databases - cd run/private/nix && ./run.sh sync + cd run/preprod/nix + rm -rf logs + mkdir -p logs + rm -rf databases + ./snapshot.sh + ./run.sh sync artifact_paths: - - "./run/private/nix/logs/*" + - "./run/preprod/nix/logs/*" agents: system: x86_64-linux env: NODE_LOGS_FILE: ./logs/node.log WALLET_LOGS_FILE: ./logs/wallet.log + - group: Code Quality Checks key: code-quality steps: diff --git a/run/preprod/nix/.env b/run/preprod/nix/.env new file mode 100644 index 00000000000..cb68696ae98 --- /dev/null +++ b/run/preprod/nix/.env @@ -0,0 +1 @@ +NETWORK="preprod" diff --git a/run/preprod/nix/configs b/run/preprod/nix/configs new file mode 120000 index 00000000000..0456cd8e3d5 --- /dev/null +++ b/run/preprod/nix/configs @@ -0,0 +1 @@ +../../../configs/cardano/preprod/ \ No newline at end of file diff --git a/run/preprod/nix/run.sh b/run/preprod/nix/run.sh new file mode 120000 index 00000000000..bba5f1e4434 --- /dev/null +++ b/run/preprod/nix/run.sh @@ -0,0 +1 @@ +../../common/nix/run.sh \ No newline at end of file From 09190a32156402edeeedf5f46e0c184a653b73cd Mon Sep 17 00:00:00 2001 From: paolino Date: Mon, 15 Jul 2024 08:40:39 +0000 Subject: [PATCH 5/6] Add note about preprod snapshots in the README --- README.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/README.md b/README.md index 1f918600b59..f88c209e619 100644 --- a/README.md +++ b/README.md @@ -145,6 +145,18 @@ On `mainnet`, the Minimum System Requirements for a `cardano-node` are high: - 200GB of disk space (for the history of blocks) - 24GB of RAM (for the current UTxO set) +### Running on preprod + +Preprod network is broken for node 9.0.0 at some block in the past. +One way to overcome that limitation is to download a snapshot that used an old version node (1.35.2) +to trespass that point. +Use `snpashot.sh` to download the snapshot. + +```bash +cd run/preprod/docker +./snapshot.sh +./run.sh sync +``` ## Obtaining `cardano-wallet` From b294ff1deac233f7174803ff5ccc1f741102d5cc Mon Sep 17 00:00:00 2001 From: paolino Date: Mon, 15 Jul 2024 08:44:36 +0000 Subject: [PATCH 6/6] Remove artifacts in docker E2E sync --- .buildkite/pipeline.yml | 6 ------ 1 file changed, 6 deletions(-) diff --git a/.buildkite/pipeline.yml b/.buildkite/pipeline.yml index d012ebd9fd2..8792c730db4 100644 --- a/.buildkite/pipeline.yml +++ b/.buildkite/pipeline.yml @@ -556,8 +556,6 @@ steps: command: | rm -rf run/private/docker/databases cd run/private/docker && ./run.sh sync - artifact_paths: - - "./run/private/docker/logs/*" agents: system: x86_64-linux concurrency: 1 @@ -576,8 +574,6 @@ steps: command: | rm -rf run/sanchonet/docker/databases cd run/sanchonet/docker && ./run.sh sync - artifact_paths: - - "./run/sanchonet/docker/logs/*" agents: system: x86_64-linux concurrency: 1 @@ -599,8 +595,6 @@ steps: # necessary to avoid the broken network ./snapshot.sh ./run.sh sync - artifact_paths: - - "./run/preprod/docker/logs/*" agents: system: x86_64-linux concurrency: 1