Some checks failed
API Endpoint Tests / test-api-endpoints (push) Failing after 36s
CLI Tests / test-cli (push) Failing after 3m9s
Documentation Validation / validate-docs (push) Successful in 8s
Integration Tests / test-service-integration (push) Failing after 3s
JavaScript SDK Tests / test-js-sdk (push) Successful in 7s
Package Tests / test-python-packages (map[name:aitbc-agent-sdk path:packages/py/aitbc-agent-sdk]) (push) Failing after 8s
Package Tests / test-python-packages (map[name:aitbc-core path:packages/py/aitbc-core]) (push) Failing after 29s
Package Tests / test-python-packages (map[name:aitbc-crypto path:packages/py/aitbc-crypto]) (push) Failing after 13s
Package Tests / test-python-packages (map[name:aitbc-sdk path:packages/py/aitbc-sdk]) (push) Failing after 16s
Package Tests / test-javascript-packages (map[name:aitbc-sdk-js path:packages/js/aitbc-sdk]) (push) Successful in 7s
Package Tests / test-javascript-packages (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Failing after 18s
Python Tests / test-python (push) Failing after 3m37s
Rust ZK Components Tests / test-rust-zk (push) Successful in 28s
Security Scanning / security-scan (push) Failing after 46s
Smart Contract Tests / test-solidity (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Failing after 18s
Smart Contract Tests / test-solidity (map[name:zk-circuits path:apps/zk-circuits]) (push) Failing after 43s
Smart Contract Tests / lint-solidity (push) Failing after 12s
Staking Tests / test-staking-service (push) Failing after 2m33s
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) Failing after 4s
- Remove `|| echo "⚠️ ..."` fallbacks that masked failures - Add explicit `exit 1` on port readiness failures and missing test directories - Track port_ready flag in health check loops to fail if services don't start - Replace warning emoji (⚠️) with error emoji (❌) for actual failures - Fix docs-validation to use curated Markdown target list excluding high-noise directories - Update rust-zk-tests paths from gpu_acceleration/research to dev
104 lines
3.3 KiB
YAML
104 lines
3.3 KiB
YAML
name: Documentation Validation
|
|
|
|
on:
|
|
push:
|
|
branches: [main, develop]
|
|
paths:
|
|
- 'docs/**'
|
|
- '*.md'
|
|
- '.gitea/workflows/docs-validation.yml'
|
|
pull_request:
|
|
branches: [main, develop]
|
|
paths:
|
|
- 'docs/**'
|
|
- '*.md'
|
|
- '.gitea/workflows/docs-validation.yml'
|
|
workflow_dispatch:
|
|
|
|
concurrency:
|
|
group: docs-validation-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
validate-docs:
|
|
runs-on: debian
|
|
timeout-minutes: 10
|
|
|
|
steps:
|
|
- name: Clone repository
|
|
run: |
|
|
WORKSPACE="/var/lib/aitbc-workspaces/docs-validation"
|
|
rm -rf "$WORKSPACE"
|
|
mkdir -p "$WORKSPACE"
|
|
cd "$WORKSPACE"
|
|
git clone --depth 1 http://gitea.bubuit.net:3000/oib/aitbc.git repo
|
|
|
|
- name: Install tools
|
|
run: |
|
|
npm install -g markdownlint-cli 2>/dev/null || echo "⚠️ markdownlint not installed"
|
|
|
|
- name: Lint Markdown files
|
|
run: |
|
|
cd /var/lib/aitbc-workspaces/docs-validation/repo
|
|
|
|
# Ensure standard directories exist
|
|
mkdir -p /var/lib/aitbc/data /var/lib/aitbc/keystore /etc/aitbc /var/log/aitbc
|
|
|
|
echo "=== Linting Markdown ==="
|
|
if command -v markdownlint >/dev/null 2>&1; then
|
|
shopt -s globstar nullglob
|
|
targets=(
|
|
*.md
|
|
docs/*.md
|
|
docs/11_agents/**/*.md
|
|
docs/agent-sdk/**/*.md
|
|
docs/blockchain/**/*.md
|
|
docs/deployment/**/*.md
|
|
docs/development/**/*.md
|
|
docs/general/**/*.md
|
|
docs/governance/**/*.md
|
|
docs/implementation/**/*.md
|
|
docs/infrastructure/**/*.md
|
|
docs/openclaw/**/*.md
|
|
docs/policies/**/*.md
|
|
docs/security/**/*.md
|
|
docs/workflows/**/*.md
|
|
)
|
|
|
|
if [[ ${#targets[@]} -eq 0 ]]; then
|
|
echo "⚠️ No curated Markdown targets matched"
|
|
else
|
|
echo "Curated advisory scope: ${#targets[@]} Markdown files"
|
|
echo "Excluded high-noise areas: about, advanced, archive, backend, beginner, completed, expert, intermediate, project, reports, summaries, trail"
|
|
markdownlint "${targets[@]}" --ignore "node_modules/**" || echo "⚠️ Markdown linting warnings in curated docs scope"
|
|
fi
|
|
else
|
|
echo "⚠️ markdownlint not available, skipping"
|
|
fi
|
|
echo "✅ Markdown linting completed"
|
|
|
|
- name: Check documentation structure
|
|
run: |
|
|
cd /var/lib/aitbc-workspaces/docs-validation/repo
|
|
echo "=== Documentation Structure ==="
|
|
for f in docs/README.md docs/MASTER_INDEX.md; do
|
|
if [[ -f "$f" ]]; then
|
|
echo " ✅ $f exists"
|
|
else
|
|
echo " ❌ $f missing"
|
|
fi
|
|
done
|
|
|
|
- name: Documentation stats
|
|
if: always()
|
|
run: |
|
|
cd /var/lib/aitbc-workspaces/docs-validation/repo
|
|
echo "=== Documentation Statistics ==="
|
|
echo " Markdown files: $(find docs -name '*.md' 2>/dev/null | wc -l)"
|
|
echo " Total size: $(du -sh docs 2>/dev/null | cut -f1)"
|
|
echo " Categories: $(ls -1 docs 2>/dev/null | wc -l)"
|
|
|
|
- name: Cleanup
|
|
if: always()
|
|
run: rm -rf /var/lib/aitbc-workspaces/docs-validation
|