Files
aitbc/.gitea/workflows/integration-tests.yml
aitbc 7a5f3487f3
All checks were successful
API Endpoint Tests / test-api-endpoints (push) Successful in 8s
CLI Tests / test-cli (push) Successful in 4s
Documentation Validation / validate-docs (push) Successful in 6s
Documentation Validation / validate-policies-strict (push) Successful in 2s
Integration Tests / test-service-integration (push) Successful in 2m9s
JavaScript SDK Tests / test-js-sdk (push) Successful in 7s
Package Tests / Python package - aitbc-agent-sdk (push) Successful in 10s
Package Tests / Python package - aitbc-core (push) Successful in 11s
Package Tests / Python package - aitbc-crypto (push) Successful in 7s
Package Tests / Python package - aitbc-sdk (push) Successful in 12s
Package Tests / JavaScript package - aitbc-sdk-js (push) Successful in 5s
Package Tests / JavaScript package - aitbc-token (push) Successful in 12s
Python Tests / test-python (push) Successful in 8s
Rust ZK Components Tests / test-rust-zk (push) Successful in 31s
Security Scanning / security-scan (push) Successful in 28s
Smart Contract Tests / test-solidity (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Successful in 18s
Smart Contract Tests / lint-solidity (push) Successful in 9s
ci: add job logging initialization to all remaining workflow files
Added setup-job-logging.sh initialization step to api-endpoint-tests.yml, cli-level1-tests.yml, docs-validation.yml (both jobs), integration-tests.yml, js-sdk-tests.yml, package-tests.yml (both jobs), python-tests.yml, rust-zk-tests.yml, security-scanning.yml, and smart-contract-tests.yml (both jobs) to ensure consistent logging across all CI workflows.
2026-04-20 12:16:45 +02:00

161 lines
5.5 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
steps:
- name: Clone repository
run: |
WORKSPACE="/var/lib/aitbc-workspaces/integration-tests"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
- name: Initialize job logging
run: |
cd /var/lib/aitbc-workspaces/integration-tests/repo
bash scripts/ci/setup-job-logging.sh
- name: Sync systemd files
if: github.event_name != 'pull_request'
run: |
cd /var/lib/aitbc-workspaces/integration-tests/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: |
echo "Starting AITBC services..."
for svc in aitbc-coordinator-api aitbc-exchange-api aitbc-wallet aitbc-blockchain-rpc aitbc-blockchain-node; do
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 not available"
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 8000 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 /var/lib/aitbc-workspaces/integration-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 "requests pytest httpx pytest-asyncio pytest-timeout click locust"
# 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 /var/lib/aitbc-workspaces/integration-tests/repo
source venv/bin/activate
export PYTHONPATH="apps/coordinator-api/src:apps/wallet/src: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
pytest tests/ -x --timeout=30 -q
fi
# Service health check integration
python3 scripts/ci/test_api_endpoints.py
echo "✅ Integration tests completed"
- name: Service status report
if: always()
run: |
echo "=== Service Status ==="
for svc in aitbc-coordinator-api aitbc-exchange-api aitbc-wallet aitbc-blockchain-rpc aitbc-blockchain-node; do
status=$(systemctl is-active "$svc" 2>/dev/null) || status="inactive"
echo " $svc: $status"
done
- name: Cleanup
if: always()
run: rm -rf /var/lib/aitbc-workspaces/integration-tests