ci: standardize Python execution across workflows and improve venv caching robustness
Some checks failed
CLI Tests / test-cli (push) Successful in 14s
Package Tests / Python package - aitbc-agent-sdk (push) Successful in 32s
Package Tests / Python package - aitbc-core (push) Successful in 23s
Package Tests / Python package - aitbc-crypto (push) Successful in 9s
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 12s
Python Tests / test-python (push) Successful in 18s
Staking Tests / test-staking-service (push) Failing after 9s
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
Some checks failed
CLI Tests / test-cli (push) Successful in 14s
Package Tests / Python package - aitbc-agent-sdk (push) Successful in 32s
Package Tests / Python package - aitbc-core (push) Successful in 23s
Package Tests / Python package - aitbc-crypto (push) Successful in 9s
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 12s
Python Tests / test-python (push) Successful in 18s
Staking Tests / test-staking-service (push) Failing after 9s
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
- Changed all Python/pip commands to use `venv/bin/python -m` pattern instead of direct tool invocation or source activation - package-tests.yml: pip, mypy, black, pytest now use `venv/bin/python -m` - python-tests.yml: ruff, pip, pytest now use `venv/bin/python -m` or `venv/bin/pytest` - staking-tests.yml: pytest now uses `venv/bin/pytest` instead of `python3 -m pytest` - Added missing dependencies to workflow
This commit is contained in:
@@ -63,28 +63,28 @@ jobs:
|
||||
--extra-packages "pytest mypy black"
|
||||
|
||||
if [[ "${{ matrix.package.name }}" == "aitbc-sdk" ]]; then
|
||||
venv/bin/pip install -q -e "$WORKSPACE/repo/packages/py/aitbc-crypto"
|
||||
venv/bin/python -m pip install -q -e "$WORKSPACE/repo/packages/py/aitbc-crypto"
|
||||
fi
|
||||
|
||||
# Install dependencies
|
||||
if [[ -f "pyproject.toml" ]]; then
|
||||
venv/bin/pip install -q -e ".[dev]" 2>/dev/null || venv/bin/pip install -q -e .
|
||||
venv/bin/python -m pip install -q -e ".[dev]" 2>/dev/null || venv/bin/python -m pip install -q -e .
|
||||
fi
|
||||
if [[ -f "requirements.txt" ]]; then
|
||||
venv/bin/pip install -q -r requirements.txt
|
||||
venv/bin/python -m pip install -q -r requirements.txt
|
||||
fi
|
||||
|
||||
# Linting
|
||||
echo "=== Linting ==="
|
||||
if [[ -d "src" ]]; then
|
||||
mypy src/ --ignore-missing-imports --no-error-summary 2>/dev/null || echo "⚠️ MyPy warnings"
|
||||
black --check src/ 2>/dev/null || echo "⚠️ Black warnings"
|
||||
venv/bin/python -m mypy src/ --ignore-missing-imports --no-error-summary 2>/dev/null || echo "⚠️ MyPy warnings"
|
||||
venv/bin/python -m black --check src/ 2>/dev/null || echo "⚠️ Black warnings"
|
||||
fi
|
||||
|
||||
# Tests
|
||||
echo "=== Tests ==="
|
||||
if [[ -d "tests" ]]; then
|
||||
pytest tests/ -q --tb=short
|
||||
venv/bin/python -m pytest tests/ -q --tb=short
|
||||
else
|
||||
echo "⚠️ No tests directory found"
|
||||
fi
|
||||
@@ -117,6 +117,7 @@ jobs:
|
||||
timeout-minutes: 30
|
||||
|
||||
strategy:
|
||||
max-parallel: 1
|
||||
matrix:
|
||||
package:
|
||||
- name: "aitbc-sdk-js"
|
||||
@@ -147,7 +148,11 @@ jobs:
|
||||
node --version
|
||||
npm --version
|
||||
|
||||
npm install --legacy-peer-deps
|
||||
if [[ -f "package-lock.json" ]]; then
|
||||
npm ci --legacy-peer-deps --no-audit --no-fund
|
||||
else
|
||||
npm install --legacy-peer-deps --no-audit --no-fund
|
||||
fi
|
||||
|
||||
# Build
|
||||
npm run build
|
||||
@@ -157,7 +162,11 @@ jobs:
|
||||
npm run lint 2>/dev/null && echo "✅ Lint passed" || echo "⚠️ Lint skipped"
|
||||
|
||||
# Test
|
||||
npm test
|
||||
if [[ "${{ matrix.package.name }}" == "aitbc-token" ]]; then
|
||||
npx hardhat test --no-compile
|
||||
else
|
||||
npm test
|
||||
fi
|
||||
echo "✅ Tests passed"
|
||||
|
||||
echo "✅ ${{ matrix.package.name }} completed"
|
||||
|
||||
Reference in New Issue
Block a user