QA - Tip tracking #15
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: QA - Tip tracking | |
on: | |
schedule: | |
- cron: '0 0 * * *' # Run every day at 00:00 AM UTC | |
jobs: | |
long-running-test: | |
runs-on: self-hosted | |
env: | |
ERIGON_REFERENCE_DATA_DIR: /opt/erigon-versions/reference-version/datadir | |
ERIGON_TESTBED_DATA_DIR: /opt/erigon-testbed/datadir | |
ERIGON_QA_PATH: /home/qarunner/erigon-qa | |
TRACKING_TIME_SECONDS: 14400 # 4 hours | |
TOTAL_TIME_SECONDS: 28800 # 8 hours | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v4 | |
- name: Set up Go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: '1.21' | |
- name: Clean Erigon Build Directory | |
run: | | |
make clean | |
- name: Build Erigon | |
run: | | |
make erigon | |
working-directory: ${{ github.workspace }} | |
- name: Pause the Erigon instance dedicated to db maintenance | |
run: | | |
curl -X POST -H "Accept: application/json" -d '{"status": "paused"}' http://localhost:8080/production/default/status || true | |
- name: Restore Erigon Testbed Data Directory | |
run: | | |
rm -rf $ERIGON_TESTBED_DATA_DIR/chaindata | |
rsync -a --delete $ERIGON_REFERENCE_DATA_DIR/ $ERIGON_TESTBED_DATA_DIR/ | |
- name: Run Erigon, wait sync and check ability to maintain sync | |
id: test_step | |
run: | | |
set +e # Disable exit on error | |
# 1. Launch the testbed Erigon instance | |
# 2. Allow time for the Erigon to achieve synchronization | |
# 3. Begin timing the duration that Erigon maintains synchronization | |
python3 $ERIGON_QA_PATH/test_system/qa-tests/tip-tracking/run_and_check_tip_tracking.py ${{ github.workspace }}/build/bin $ERIGON_TESTBED_DATA_DIR $TRACKING_TIME_SECONDS $TOTAL_TIME_SECONDS | |
# Capture monitoring script exit status | |
test_exit_status=$? | |
# Clean up Erigon process if it's still running | |
if kill -0 $ERIGON_PID 2> /dev/null; then | |
echo "Terminating Erigon" | |
kill $ERIGON_PID | |
wait $ERIGON_PID | |
else | |
echo "Erigon has already terminated" | |
fi | |
# Check test runner script exit status | |
if [ $test_exit_status -eq 0 ]; then | |
echo "Tests completed successfully" | |
echo "TEST_RESULT=success" >> "$GITHUB_OUTPUT" | |
else | |
echo "Error detected during tests" | |
echo "TEST_RESULT=failure" >> "$GITHUB_OUTPUT" | |
fi | |
- name: Resume the Erigon instance dedicated to db maintenance | |
run: | | |
python3 $ERIGON_QA_PATH/test_system/db-producer/resume_production.py || true | |
- name: Save test results | |
if: always() | |
env: | |
TEST_RESULT: ${{ steps.test_step.outputs.TEST_RESULT }} | |
run: python3 $ERIGON_QA_PATH/test_system/qa-tests/uploads/upload_test_results.py --repo erigon --commit $(git rev-parse HEAD) --test_name tip-tracking --outcome $TEST_RESULT --result_file ${{ github.workspace }}/result.json | |
- name: Upload test results | |
if: always() | |
uses: actions/upload-artifact@v4 | |
with: | |
name: test-results | |
path: ${{ github.workspace }}/result.json | |
- name: Action for Success | |
if: steps.test_step.outputs.TEST_RESULT == 'success' | |
run: echo "::notice::Tests completed successfully" | |
- name: Action for Not Success | |
if: steps.test_step.outputs.TEST_RESULT != 'success' | |
run: | | |
echo "::error::Error detected during tests" | |
exit 1 |