Files
aitbc/.gitea/workflows/staking-tests.yml
aitbc 39988af60b
Some checks failed
CLI Tests / test-cli (push) Failing after 15s
Package Tests / Python package - aitbc-agent-sdk (push) Failing after 4s
Package Tests / Python package - aitbc-core (push) Failing after 2s
Package Tests / Python package - aitbc-crypto (push) Failing after 2s
Package Tests / Python package - aitbc-sdk (push) Failing after 4s
Package Tests / JavaScript package - aitbc-sdk-js (push) Failing after 26m1s
Package Tests / JavaScript package - aitbc-token (push) Failing after 27s
Python Tests / test-python (push) Failing after 20s
Staking Tests / test-staking-service (push) Failing after 10s
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
ci: standardize venv setup with --skip-requirements and explicit test dependencies across workflows
- Added --skip-requirements flag to cli-level1-tests.yml, python-tests.yml, and staking-tests.yml
- Specified explicit test package dependencies via --extra-packages instead of relying on requirements files
  - cli-level1-tests.yml: pytest click typer rich
  - python-tests.yml: pytest pytest-cov pytest-mock pytest-timeout pytest-asyncio locust
  - staking-tests.yml: pytest pytest-asyncio
- Increased
2026-04-20 06:44:09 +02:00

181 lines
5.5 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
steps:
- name: Clone repository
run: |
WORKSPACE="/var/lib/aitbc-workspaces/staking-tests"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Setup Python environment
run: |
cd /var/lib/aitbc-workspaces/staking-tests/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"
echo "✅ Python environment ready"
- name: Run staking service tests
run: |
cd /var/lib/aitbc-workspaces/staking-tests/repo
source venv/bin/activate
export PYTHONPATH="apps/coordinator-api/src:."
echo "🧪 Running staking service tests..."
python3 -m pytest tests/services/test_staking_service.py -v --tb=short
echo "✅ Service tests completed"
- name: Generate test data
run: |
cd /var/lib/aitbc-workspaces/staking-tests/repo
source venv/bin/activate
echo "🔧 Generating test data..."
python3 scripts/testing/generate_staking_test_data.py
echo "✅ Test data generated"
- name: Cleanup
if: always()
run: rm -rf /var/lib/aitbc-workspaces/staking-tests
test-staking-integration:
runs-on: debian
timeout-minutes: 20
needs: test-staking-service
steps:
- name: Clone repository
run: |
WORKSPACE="/var/lib/aitbc-workspaces/staking-integration"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Setup Python environment
run: |
cd /var/lib/aitbc-workspaces/staking-integration/repo
bash scripts/ci/setup-python-venv.sh \
--repo-dir "$PWD" \
--venv-dir "$PWD/venv"
echo "✅ Python environment ready"
- name: Run staking integration tests
run: |
cd /var/lib/aitbc-workspaces/staking-integration/repo
source venv/bin/activate
export PYTHONPATH="apps/coordinator-api/src:."
echo "🧪 Running staking integration tests..."
python3 -m pytest tests/integration/test_staking_lifecycle.py -v --tb=short
echo "✅ Integration tests completed"
- name: Cleanup
if: always()
run: rm -rf /var/lib/aitbc-workspaces/staking-integration
test-staking-contract:
runs-on: debian
timeout-minutes: 15
needs: test-staking-service
steps:
- name: Clone repository
run: |
WORKSPACE="/var/lib/aitbc-workspaces/staking-contract"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Setup Node.js environment
run: |
cd /var/lib/aitbc-workspaces/staking-contract/repo/contracts
npm install
echo "✅ Node.js environment ready"
- name: Run staking contract tests
run: |
cd /var/lib/aitbc-workspaces/staking-contract/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 /var/lib/aitbc-workspaces/staking-contract
run-staking-test-runner:
runs-on: debian
timeout-minutes: 25
needs: [test-staking-service, test-staking-integration, test-staking-contract]
steps:
- name: Clone repository
run: |
WORKSPACE="/var/lib/aitbc-workspaces/staking-runner"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Setup Python environment
run: |
cd /var/lib/aitbc-workspaces/staking-runner/repo
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 /var/lib/aitbc-workspaces/staking-runner/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 /var/lib/aitbc-workspaces/staking-runner