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
- 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
189 lines
6.1 KiB
YAML
189 lines
6.1 KiB
YAML
name: Integration Tests
|
|
|
|
on:
|
|
push:
|
|
branches: [main, develop]
|
|
paths:
|
|
- 'apps/**'
|
|
- 'packages/**'
|
|
- '.gitea/workflows/integration-tests.yml'
|
|
pull_request:
|
|
branches: [main, develop]
|
|
workflow_dispatch:
|
|
|
|
concurrency:
|
|
group: integration-tests-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
test-service-integration:
|
|
runs-on: debian
|
|
timeout-minutes: 15
|
|
|
|
env:
|
|
WORKSPACE: /var/lib/aitbc-workspaces/integration-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: Sync systemd files
|
|
if: github.event_name != 'pull_request'
|
|
run: |
|
|
cd "${{ env.WORKSPACE }}/repo"
|
|
if [[ -d "systemd" ]]; then
|
|
echo "Linking systemd service files..."
|
|
if [[ -x scripts/utils/link-systemd.sh ]]; then
|
|
if [[ $EUID -eq 0 ]]; then
|
|
./scripts/utils/link-systemd.sh
|
|
else
|
|
sudo ./scripts/utils/link-systemd.sh
|
|
fi
|
|
echo "✅ Systemd files linked"
|
|
else
|
|
echo "❌ scripts/utils/link-systemd.sh not found"
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
- name: Start services
|
|
if: github.event_name != 'pull_request'
|
|
run: |
|
|
cd "${{ env.WORKSPACE }}/repo"
|
|
echo "Starting AITBC services..."
|
|
mapfile -t services < <(
|
|
find systemd -maxdepth 1 -type f -name "aitbc-*.service" -printf "%f\n" |
|
|
sed 's/\.service$//' |
|
|
sort
|
|
)
|
|
|
|
if [[ ${#services[@]} -eq 0 ]]; then
|
|
echo "⚠️ No aitbc service files found to start"
|
|
fi
|
|
|
|
for svc in "${services[@]}"; do
|
|
if systemctl list-unit-files | grep -q "^$svc.service"; then
|
|
if systemctl is-active --quiet "$svc" 2>/dev/null; then
|
|
echo "✅ $svc already running"
|
|
else
|
|
systemctl start "$svc" 2>/dev/null && echo "✅ $svc started" || echo "⚠️ $svc failed to start"
|
|
fi
|
|
else
|
|
echo "⚠️ $svc service file not found"
|
|
fi
|
|
sleep 1
|
|
done
|
|
|
|
- name: Wait for services ready
|
|
id: wait-services
|
|
continue-on-error: true
|
|
run: |
|
|
echo "Waiting for services..."
|
|
services_available=true
|
|
for port in 9001 8001 8003 8006; do
|
|
port_ready=0
|
|
for i in $(seq 1 15); do
|
|
code=$(curl -so /dev/null -w '%{http_code}' "http://localhost:$port/health" 2>/dev/null) || code=0
|
|
if [ "$code" -gt 0 ] && [ "$code" -lt 600 ]; then
|
|
echo "✅ Port $port ready (HTTP $code)"
|
|
port_ready=1
|
|
break
|
|
fi
|
|
# Try alternate paths
|
|
code=$(curl -so /dev/null -w '%{http_code}' "http://localhost:$port/api/health" 2>/dev/null) || code=0
|
|
if [ "$code" -gt 0 ] && [ "$code" -lt 600 ]; then
|
|
echo "✅ Port $port ready (HTTP $code)"
|
|
port_ready=1
|
|
break
|
|
fi
|
|
code=$(curl -so /dev/null -w '%{http_code}' "http://localhost:$port/" 2>/dev/null) || code=0
|
|
if [ "$code" -gt 0 ] && [ "$code" -lt 600 ]; then
|
|
echo "✅ Port $port ready (HTTP $code)"
|
|
port_ready=1
|
|
break
|
|
fi
|
|
[ "$i" -eq 15 ] && echo "⚠️ Port $port not ready"
|
|
sleep 2
|
|
done
|
|
|
|
if [[ $port_ready -ne 1 ]]; then
|
|
services_available=false
|
|
fi
|
|
done
|
|
|
|
echo "services_available=$services_available" >> $GITHUB_OUTPUT
|
|
if [[ $services_available == "false" ]]; then
|
|
echo "⚠️ Not all services ready - integration tests will be skipped"
|
|
exit 0
|
|
fi
|
|
|
|
- name: Setup test 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"
|
|
|
|
# Ensure standard directories exist
|
|
mkdir -p /var/lib/aitbc/data /var/lib/aitbc/keystore /etc/aitbc /var/log/aitbc
|
|
|
|
- name: Run integration tests
|
|
run: |
|
|
cd "${{ env.WORKSPACE }}/repo"
|
|
source venv/bin/activate
|
|
export PYTHONPATH="$PWD/cli:$PWD/apps/agent-coordinator/src:$PWD/apps/wallet/src:$PWD/apps/exchange/src:$PYTHONPATH"
|
|
|
|
# Skip if services not available
|
|
if [ "${{ steps.wait-services.outputs.services_available }}" != "true" ]; then
|
|
echo "⚠️ Services not available - skipping integration tests"
|
|
exit 0
|
|
fi
|
|
|
|
# Run existing test suites
|
|
if [[ -d "tests" ]]; then
|
|
venv/bin/python -m pytest -c /dev/null --rootdir "$PWD" --import-mode=importlib tests/ -x --timeout=30 -q --ignore=tests/production
|
|
fi
|
|
|
|
# Service health check integration (now tests both chains)
|
|
python3 scripts/ci/test_api_endpoints.py
|
|
echo "✅ Integration tests completed"
|
|
|
|
- name: Service status report
|
|
if: always()
|
|
run: |
|
|
cd "${{ env.WORKSPACE }}/repo"
|
|
echo "=== Service Status ==="
|
|
|
|
mapfile -t services < <(
|
|
find systemd -maxdepth 1 -type f -name "aitbc-*.service" -printf "%f\n" |
|
|
sed 's/\.service$//' |
|
|
sort
|
|
)
|
|
|
|
if [[ ${#services[@]} -eq 0 ]]; then
|
|
echo "⚠️ No aitbc service files found"
|
|
exit 0
|
|
fi
|
|
|
|
for svc in "${services[@]}"; do
|
|
status=$(systemctl is-active "$svc" 2>/dev/null) || status="inactive"
|
|
echo " $svc: $status"
|
|
done
|
|
|
|
- name: Cleanup
|
|
if: always()
|
|
run: rm -rf "${{ env.WORKSPACE }}"
|