Skip to content

Commit

Permalink
Add sync check for rust webrtc nodes on devnet
Browse files Browse the repository at this point in the history
  • Loading branch information
kaozenn committed Dec 2, 2024
1 parent ad57abc commit f8267bd
Show file tree
Hide file tree
Showing 3 changed files with 110 additions and 9 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Daily Seed Synchronization Check
name: oCaml Seed Synchronization Check
on:
workflow_dispatch:
schedule:
Expand All @@ -18,7 +18,7 @@ jobs:
id: parse-mainnet-seed-list
run: |
echo "Parsing Mainnet Seed List"
seeds=$(cat networks/mainnet.txt | jq -R -s -c 'split("\n") | map(select(. != ""))')
seeds=$(cat networks/devnet-webrtc.txt | jq -R -s -c 'split("\n") | map(select(. != ""))')
echo "seeds=$seeds" >> $GITHUB_OUTPUT
test-peer:
needs: parse-mainnet-seed-list
Expand All @@ -36,12 +36,14 @@ jobs:
echo "Starting Mina Daemon"
docker run -d --restart always --name mina \
--entrypoint="" \
minaprotocol/mina-daemon:3.0.0-93e0279-bullseye-mainnet \
minaprotocol/mina-daemon:${{ env.MINA_TAG }} \
mina daemon \
--peer ${{ matrix.seed }}
env:
MINA_TAG: 3.0.3-d800da8-focal-mainnet
- name: Wait for Daemon to Sync
id: wait-for-sync
run: ./scripts/mina-sync-monitor.sh
run: ./scripts/mina-sync-monitor.sh ocaml
- name: Record Failing Seed
id: record-fail
if: ${{ failure() }}
Expand Down Expand Up @@ -76,7 +78,7 @@ jobs:
if: ${{ success() }}
uses: slackapi/[email protected]
with:
channel-id: "mf-alerts-info"
channel-id: "mf-alerts-test"
payload-file-path: "./payload-slack-content.json"
env:
SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }}
83 changes: 83 additions & 0 deletions .github/workflows/rust-sync-check.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
name: Rust Seed Synchronization Check
on:
workflow_dispatch:
schedule:
- cron: "0 */3 * * *" # Every 3 Hours
concurrency:
group: "${{ github.workflow }} @ ${{ github.event.pull_request.head.label || github.head_ref || github.ref }}"
cancel-in-progress: true
jobs:
parse-mainnet-seed-list:
runs-on: minafoundation-default-interruptible-runners
outputs:
seeds: ${{ steps.parse-mainnet-seed-list.outputs.seeds }}
steps:
- name: 📥 Checkout
uses: actions/[email protected]
- name: Parse Mainnet Seed List
id: parse-mainnet-seed-list
run: |
echo "Parsing Mainnet Seed List"
seeds=$(cat networks/devnet-webrtc.txt | jq -R -s -c 'split("\n") | map(select(. != ""))')
echo "seeds=$seeds" >> $GITHUB_OUTPUT
test-peer:
needs: parse-mainnet-seed-list
runs-on: minafoundation-default-interruptible-runners
if: needs.parse-mainnet-seed-list.outputs.seeds != '[]' && needs.parse-mainnet-seed-list.outputs.seeds != ''
continue-on-error: true
strategy:
matrix:
seed: ${{ fromJson(needs.parse-mainnet-seed-list.outputs.seeds) }}
steps:
- name: 📥 Checkout
uses: actions/[email protected]
- name: Start Mina Daemon
run: |
echo "Starting Mina Daemon"
docker run --rm -d --name openmina \
openmina/openmina:${{ env.MINA_TAG }} \
node \
--peers ${{ matrix.seed }}
env:
MINA_TAG: v0.11.4
- name: Wait for Daemon to Sync
id: wait-for-sync
run: ./scripts/mina-sync-monitor.sh rust
- name: Record Failing Seed
id: record-fail
if: ${{ failure() }}
run: |
echo "Update Failed Seed List"
echo "${{ matrix.seed }}" > failed-seeds-${{strategy.job-index}}.txt
- name: Upload failed seeds
if: ${{ failure() }}
uses: actions/[email protected]
with:
name: failed-seeds-${{strategy.job-index}}
path: failed-seeds-${{strategy.job-index}}.txt
retention-days: 1

print-failed-seeds:
needs: test-peer
runs-on: minafoundation-default-interruptible-runners
continue-on-error: true
steps:
- name: Download all artifacts
uses: actions/download-artifact@v4
with:
pattern: "failed-seeds-*" # Use a wildcard to download all artifacts matching the pattern
- name: Echo Failed Seeds
run: |
cat failed-seeds-*/failed-seeds-*.txt > failed-seeds.txt || exit 0
jq -n --arg message "Failed to synchronize with Mina Daemon using seed peer:" \
--argjson seeds "$(cat failed-seeds.txt | jq -R . | jq -s .)" \
'{text: ($message + "\n\n" + ($seeds | map("• " + .) | join("\n")))}' > payload-slack-content.json
- name: Post to a Slack channel
id: slack
if: ${{ success() }}
uses: slackapi/[email protected]
with:
channel-id: "mf-alerts-testing"
payload-file-path: "./payload-slack-content.json"
env:
SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }}
24 changes: 20 additions & 4 deletions scripts/mina-sync-monitor.sh
Original file line number Diff line number Diff line change
@@ -1,25 +1,41 @@
#!/usr/bin/env bash
set -e

max_attempts=40
attempt=0
sleep_duration=500
status="Null"
sleep_duration=500
sync_check_command_ocaml="docker exec mina mina client status --json | jq -r .sync_status"
sync_check_command_rust="docker exec openmina curl -s http://localhost:3000/status | jq -r .transition_frontier.sync.status"

check_sync_status() {
status=$(docker exec mina mina client status --json | jq -r .sync_status || echo "Null")
if [ "$1" == "ocaml" ]; then
status=$(eval "$sync_check_command_ocaml" || echo "Null")
elif [ "$1" == "rust" ]; then
status=$(eval "$sync_check_command_rust" || echo "Null")
else
status="Null"
fi
echo "Current sync status: $status"
}

# Loop to check sync status
while [ $attempt -lt $max_attempts ]; do
check_sync_status
if [ "$1" == "ocaml" ]; then
check_sync_status "ocaml"
elif [ "$1" == "rust" ]; then
check_sync_status "rust"
else
echo "Invalid container type. Please specify 'ocaml' or 'rust'."
exit 1
fi

if [ "$status" == "Synced" ]; then
echo "Mina client is synced."
exit 0
fi

attempt=$((attempt + 1))

echo "Mina daemon is not synced. Attempt $attempt/$max_attempts."
sleep $sleep_duration
done
Expand Down

0 comments on commit f8267bd

Please sign in to comment.