Files
aitbc/.gitea/workflows/python-tests.yml
aitbc 573aae065b
Some checks failed
API Endpoint Tests / test-api-endpoints (push) Successful in 56s
Blockchain Synchronization Verification / sync-verification (push) Failing after 3s
CLI Tests / test-cli (push) Failing after 5s
Coverage Phase 1 (70% Target) / test-coverage-70 (push) Failing after 19s
Coverage Phase 2 (85% Target) / test-coverage-85 (push) Failing after 18s
Cross-Chain Functionality Tests / test-cross-chain-sync (push) Successful in 3s
Cross-Chain Functionality Tests / test-cross-chain-transactions (push) Successful in 4s
Cross-Chain Functionality Tests / test-multi-chain-consensus (push) Successful in 5s
Deploy to Testnet / deploy-testnet (push) Failing after 21s
Documentation Validation / validate-docs (push) Failing after 13s
Documentation Validation / validate-policies-strict (push) Successful in 4s
Integration Tests / test-service-integration (push) Failing after 2s
Multi-Chain Island Architecture Tests / test-multi-chain-island (push) Successful in 4s
Multi-Node Blockchain Health Monitoring / health-check (push) Failing after 14s
Node Failover Simulation / failover-test (push) Successful in 9s
P2P Network Verification / p2p-verification (push) Successful in 5s
Package Tests / Python package - aitbc-agent-sdk (push) Successful in 51s
Package Tests / Python package - aitbc-core (push) Failing after 3s
Package Tests / Python package - aitbc-crypto (push) Successful in 22s
Package Tests / Python package - aitbc-sdk (push) Successful in 16s
Package Tests / JavaScript package - aitbc-sdk-js (push) Successful in 21s
Package Tests / JavaScript package - aitbc-token (push) Failing after 18s
Production Tests / Production Integration Tests (push) Failing after 1m9s
Python Tests / test-python (push) Failing after 3s
Security Scanning / security-scan (push) Failing after 41s
Smart Contract Tests / test-solidity (map[name:aitbc-contracts path:contracts]) (push) Failing after 6s
Smart Contract Tests / test-solidity (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Failing after 7s
Smart Contract Tests / test-foundry (push) Failing after 20s
Smart Contract Tests / lint-solidity (push) Failing after 4s
Smart Contract Tests / deploy-contracts (push) Failing after 5s
Cross-Chain Functionality Tests / aggregate-results (push) Successful in 2s
Multi-Node Stress Testing / stress-test (push) Successful in 2s
Cross-Node Transaction Testing / transaction-test (push) Successful in 3s
feat: complete codebase remediation with all phases
Phase 1: Security fixes
- Added CORSMiddleware to marketplace-service with specific origins
- Fixed blockchain-node auth to fail closed on JWT errors
- Added security regression tests (test_cors_configuration.py, test_dispute_auth.py)

Phase 2: Repository cleanup
- Removed 51 fix/backup/legacy files
- Deleted marketplace-service-debug directory

Phase 3.1: Python version constraints
- Updated aitbc-crypto and aitbc-sdk with requires-python >=3.13
- Added explicit [tool.poetry].packages declarations

Phase 3.2: Agent service DI architecture
- Created aitbc-agent-core package with protocols and shared service
- Implemented adapters for agent-management and coordinator-api
- Created factory functions for gradual migration
- Added migration comments to existing integration files

Phase 4.1: Auth/utils extraction
- Created auth.py module with JWT validation and security utilities
- Created utils.py module with common helpers

Phase 4.2: Router decomposition
- Decomposed router.py into 10 domain modules (58 endpoints)
- Created route table snapshot for verification
- Preserved router_old.py as reference

Phase 5: App shell classification
- Documented app shell patterns across services

Phase 6: Quality gates
- Verified mypy type checking (75% error reduction)
- Analyzed logging inconsistencies with structlog migration plan
- Removed unused orjson dependency

Documentation:
- Created comprehensive remediation report
- Added architecture documentation for DI pattern
- Added quality analysis documents
2026-05-24 20:21:23 +02:00

124 lines
4.3 KiB
YAML

name: Python Tests
on:
push:
branches: [main, develop]
paths:
- 'apps/**/*.py'
- 'packages/py/**'
- 'tests/**'
- 'pyproject.toml'
- 'requirements.txt'
- '.gitea/workflows/python-tests.yml'
pull_request:
branches: [main, develop]
workflow_dispatch:
concurrency:
group: python-tests-${{ github.ref }}
cancel-in-progress: true
jobs:
test-python:
runs-on: debian
timeout-minutes: 15
env:
WORKSPACE: /var/lib/aitbc-workspaces/python-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
# Ensure standard directories exist
mkdir -p /var/lib/aitbc/data /var/lib/aitbc/keystore /etc/aitbc /var/log/aitbc
bash scripts/ci/setup-python-venv.sh \
--repo-dir "$PWD" \
--venv-dir "$PWD/venv" \
--skip-requirements \
--mode copy \
--extra-packages "pytest pytest-cov pytest-mock pytest-timeout pytest-asyncio locust pydantic-settings fastapi uvicorn aiohttp>=3.12.14 sqlmodel>=0.0.38 PyJWT"
echo "✅ Python environment ready"
- name: Check requirements.txt sync
run: |
cd "${{ env.WORKSPACE }}/repo"
venv/bin/python scripts/ci/check-requirements-sync.py
- name: Run linting
run: |
cd "${{ env.WORKSPACE }}/repo"
if venv/bin/python -m ruff --version >/dev/null 2>&1; then
venv/bin/python -m ruff check apps/ packages/py/ --select E,F --ignore E501 -q || echo "⚠️ Ruff warnings"
fi
echo "✅ Linting completed"
- name: Run repository tests with coverage
run: |
cd "${{ env.WORKSPACE }}/repo"
# Install packages in development mode
venv/bin/python -m pip install -e packages/py/aitbc-crypto/
venv/bin/python -m pip install -e packages/py/aitbc-sdk/
venv/bin/python -m pip install -e packages/py/aitbc-agent-sdk/
export PYTHONPATH="$PWD/apps/coordinator-api/src:$PWD/apps/blockchain-node/src:$PWD/apps/wallet/src:$PWD/packages/py/aitbc-crypto/src:$PWD/packages/py/aitbc-sdk/src:$PWD/packages/py/aitbc-agent-sdk/src:$PWD:$PYTHONPATH"
venv/bin/python -m pytest tests/archived_phase_tests/ \
tests/cross_phase/ \
tests/verification/ \
-c /dev/null --rootdir "$PWD" --import-mode=importlib \
--tb=short -q --timeout=30 \
-o asyncio_mode=auto \
--cov=apps --cov=packages --cov=cli --cov-append \
--cov-report=term-missing --cov-report=html \
--cov-fail-under=50
- name: Run app and package tests with coverage
run: |
cd "${{ env.WORKSPACE }}/repo"
export PYTHONPATH="$PWD/apps/coordinator-api:$PWD/apps/coordinator-api/src:$PWD/packages/py/aitbc-crypto/src:$PWD/packages/py/aitbc-sdk/src:$PWD:$PYTHONPATH"
# Test if packages are importable
venv/bin/python -c "import aitbc_crypto; print('✅ aitbc_crypto imported')"
venv/bin/python -c "import aitbc_sdk; print('✅ aitbc_sdk imported')"
venv/bin/python -c "import src.app; print('✅ coordinator-api src.app imported')"
venv/bin/python -c "import app; print('✅ coordinator-api app imported')"
venv/bin/python -m pytest \
apps/coordinator-api/tests/test_communication.py \
packages/py/aitbc-crypto/tests/ \
packages/py/aitbc-sdk/tests/ \
-c /dev/null --rootdir "$PWD" --import-mode=importlib \
--tb=short -q --timeout=30 \
--cov=apps --cov=packages --cov=cli --cov-append
venv/bin/python -m coverage report --show-missing
venv/bin/python -m coverage xml
echo "✅ Python tests completed with coverage"
- name: Cleanup
if: always()
run: rm -rf "${{ env.WORKSPACE }}"