Files
aitbc/.gitea/workflows/staking-tests.yml
aitbc 5ffba8fb1f
Some checks failed
Cross-Node Transaction Testing / transaction-test (push) Has been cancelled
Deploy to Testnet / deploy-testnet (push) Has been cancelled
Multi-Node Stress Testing / stress-test (push) Has been cancelled
API Endpoint Tests / test-api-endpoints (push) Successful in 29s
CLI Tests / test-cli (push) Failing after 13s
Contract Performance Benchmarks / benchmark-gas-usage (push) Successful in 1m39s
Contract Performance Benchmarks / benchmark-execution-time (push) Successful in 1m30s
Contract Performance Benchmarks / benchmark-throughput (push) Successful in 1m33s
Documentation Validation / validate-docs (push) Failing after 12s
Documentation Validation / validate-policies-strict (push) Successful in 4s
Integration Tests / test-service-integration (push) Successful in 2m42s
JavaScript SDK Tests / test-js-sdk (push) Successful in 8s
Multi-Chain Island Architecture Tests / test-multi-chain-island (push) Successful in 3s
Multi-Node Blockchain Health Monitoring / health-check (push) Successful in 3s
P2P Network Verification / p2p-verification (push) Successful in 3s
Package Tests / Python package - aitbc-agent-sdk (push) Failing after 33s
Package Tests / Python package - aitbc-core (push) Successful in 17s
Package Tests / Python package - aitbc-crypto (push) Successful in 12s
Package Tests / Python package - aitbc-sdk (push) Successful in 13s
Package Tests / JavaScript package - aitbc-sdk-js (push) Successful in 7s
Package Tests / JavaScript package - aitbc-token (push) Successful in 16s
Production Tests / Production Integration Tests (push) Failing after 7s
Python Tests / test-python (push) Failing after 47s
Rust ZK Components Tests / test-rust-zk (push) Successful in 38s
Security Scanning / security-scan (push) Successful in 38s
Smart Contract Tests / test-solidity (map[name:aitbc-contracts path:contracts]) (push) Failing after 1m41s
Smart Contract Tests / test-solidity (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Successful in 16s
Smart Contract Tests / test-foundry (push) Failing after 16s
Smart Contract Tests / lint-solidity (push) Successful in 22s
Smart Contract Tests / deploy-contracts (push) Successful in 1m47s
Staking Tests / test-staking-service (push) Failing after 4s
Staking Tests / test-staking-integration (push) Has been skipped
Staking Tests / test-staking-contract (push) Has been skipped
Staking Tests / run-staking-test-runner (push) Has been skipped
Systemd Sync / sync-systemd (push) Successful in 27s
Contract Performance Benchmarks / compare-benchmarks (push) Successful in 2s
ci: refactor Gitea workflows to use environment variables for workspace paths
- Added WORKSPACE env variable to all workflow jobs
- Changed hardcoded workspace paths to use ${{ env.WORKSPACE }}
- Updated paths in api-endpoint-tests.yml, build-miner-binary.yml, cli-level1-tests.yml, contract-benchmarks.yml, cross-node-transaction-testing.yml, and deployment-tests.yml
- Standardized workspace path references across all workflow files
2026-05-11 14:52:36 +02:00

210 lines
6.2 KiB
YAML

name: Staking Tests
on:
push:
branches: [main, develop]
paths:
- 'tests/services/test_staking_service.py'
- 'tests/integration/test_staking_lifecycle.py'
- 'contracts/test/AgentStaking.test.js'
- 'apps/coordinator-api/src/app/services/staking_service.py'
- 'apps/coordinator-api/src/app/domain/bounty.py'
- '.gitea/workflows/staking-tests.yml'
pull_request:
branches: [main, develop]
workflow_dispatch:
concurrency:
group: staking-tests-${{ github.ref }}
cancel-in-progress: true
jobs:
test-staking-service:
runs-on: debian
timeout-minutes: 15
env:
WORKSPACE: /var/lib/aitbc-workspaces/staking-tests
steps:
- name: Clone repository
run: |
rm -rf "${{ env.WORKSPACE }}"
mkdir -p "${{ env.WORKSPACE }}"
cd "${{ env.WORKSPACE }}"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Initialize job logging
run: |
cd "${{ env.WORKSPACE }}/repo"
bash scripts/ci/setup-job-logging.sh
- name: Setup Python environment
run: |
cd "${{ env.WORKSPACE }}/repo"
# Remove any existing venv to avoid cache corruption issues
rm -rf venv
bash scripts/ci/setup-python-venv.sh \
--repo-dir "$PWD" \
--venv-dir "$PWD/venv" \
--skip-requirements \
--extra-packages "pytest pytest-asyncio sqlmodel click"
echo "✅ Python environment ready"
- name: Run staking service tests
run: |
cd "${{ env.WORKSPACE }}/repo"
export PYTHONPATH="$PWD/apps/coordinator-api/src:$PWD:$PYTHONPATH"
echo "🧪 Running staking service tests..."
venv/bin/python -m pytest -c /dev/null --rootdir "$PWD" --import-mode=importlib tests/services/test_staking_service.py -v --tb=short
echo "✅ Service tests completed"
- name: Generate test data
run: |
cd "${{ env.WORKSPACE }}/repo"
echo "🔧 Generating test data..."
venv/bin/python scripts/testing/generate_staking_test_data.py
echo "✅ Test data generated"
- name: Cleanup
if: always()
run: rm -rf "${{ env.WORKSPACE }}"
test-staking-integration:
runs-on: debian
timeout-minutes: 20
needs: test-staking-service
env:
WORKSPACE: /var/lib/aitbc-workspaces/staking-integration
steps:
- name: Clone repository
run: |
rm -rf "${{ env.WORKSPACE }}"
mkdir -p "${{ env.WORKSPACE }}"
cd "${{ env.WORKSPACE }}"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Initialize job logging
run: |
cd "${{ env.WORKSPACE }}/repo"
bash scripts/ci/setup-job-logging.sh
- name: Setup Python environment
run: |
cd "${{ env.WORKSPACE }}/repo"
rm -rf venv
bash scripts/ci/setup-python-venv.sh \
--repo-dir "$PWD" \
--venv-dir "$PWD/venv" \
--skip-requirements \
--extra-packages "pytest pytest-asyncio sqlmodel click"
echo "✅ Python environment ready"
- name: Run staking integration tests
run: |
cd "${{ env.WORKSPACE }}/repo"
export PYTHONPATH="$PWD/apps/coordinator-api/src:$PWD:$PYTHONPATH"
echo "🧪 Running staking integration tests..."
venv/bin/python -m pytest -c /dev/null --rootdir "$PWD" --import-mode=importlib tests/integration/test_staking_lifecycle.py -v --tb=short
echo "✅ Integration tests completed"
- name: Cleanup
if: always()
run: rm -rf "${{ env.WORKSPACE }}"
test-staking-contract:
runs-on: debian
timeout-minutes: 15
needs: test-staking-service
env:
WORKSPACE: /var/lib/aitbc-workspaces/staking-contract
steps:
- name: Clone repository
run: |
rm -rf "${{ env.WORKSPACE }}"
mkdir -p "${{ env.WORKSPACE }}"
cd "${{ env.WORKSPACE }}"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Initialize job logging
run: |
cd "${{ env.WORKSPACE }}/repo"
bash scripts/ci/setup-job-logging.sh
- name: Setup Node.js environment
run: |
cd "${{ env.WORKSPACE }}/repo/contracts"
npm install
echo "✅ Node.js environment ready"
- name: Run staking contract tests
run: |
cd "${{ env.WORKSPACE }}/repo/contracts"
echo "🧪 Running staking contract tests..."
npx hardhat compile
npx hardhat test test/AgentStaking.test.js
echo "✅ Contract tests completed"
- name: Cleanup
if: always()
run: rm -rf "${{ env.WORKSPACE }}"
run-staking-test-runner:
runs-on: debian
timeout-minutes: 25
needs: [test-staking-service, test-staking-integration, test-staking-contract]
env:
WORKSPACE: /var/lib/aitbc-workspaces/staking-runner
steps:
- name: Clone repository
run: |
rm -rf "${{ env.WORKSPACE }}"
mkdir -p "${{ env.WORKSPACE }}"
cd "${{ env.WORKSPACE }}"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Initialize job logging
run: |
cd "${{ env.WORKSPACE }}/repo"
bash scripts/ci/setup-job-logging.sh
- name: Setup Python environment
run: |
cd "${{ env.WORKSPACE }}/repo"
rm -rf venv
bash scripts/ci/setup-python-venv.sh \
--repo-dir "$PWD" \
--venv-dir "$PWD/venv"
echo "✅ Python environment ready"
- name: Run staking test runner
run: |
cd "${{ env.WORKSPACE }}/repo"
chmod +x scripts/testing/run_staking_tests.sh
bash scripts/testing/run_staking_tests.sh
echo "✅ Staking test runner completed"
- name: Upload test reports
if: always()
run: |
echo "📊 Test reports available in /var/log/aitbc/tests/staking/"
- name: Cleanup
if: always()
run: rm -rf "${{ env.WORKSPACE }}"