Files
aitbc/.gitea/workflows/docs-validation.yml
aitbc 5ffba8fb1f
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
ci: refactor Gitea workflows to use environment variables for workspace paths
- 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
2026-05-11 14:52:36 +02:00

266 lines
8.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
env:
WORKSPACE_BASE: /var/lib/aitbc-workspaces
REPO_URL: http://gitea.bubuit.net:3000/oib/aitbc.git
STANDARD_DIRS: /var/lib/aitbc/data /var/lib/aitbc/keystore /etc/aitbc /var/log/aitbc
jobs:
validate-docs:
runs-on: debian
timeout-minutes: 10
steps:
- name: Clone repository
run: |
WORKSPACE="${{ env.WORKSPACE_BASE }}/docs-validation"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 "${{ env.REPO_URL }}" repo
- name: Initialize job logging
run: |
cd "${{ env.WORKSPACE_BASE }}/docs-validation/repo"
bash scripts/ci/setup-job-logging.sh
- name: Ensure standard directories
run: mkdir -p ${{ env.STANDARD_DIRS }}
- name: Install tools
run: |
npm install -g markdownlint-cli 2>/dev/null || echo "⚠️ markdownlint not installed"
- name: Lint Markdown files
run: |
cd "${{ env.WORKSPACE_BASE }}/docs-validation/repo"
echo "=== Linting Markdown ==="
if command -v markdownlint >/dev/null 2>&1; then
shopt -s globstar nullglob
targets=(
*.md
docs/*.md
docs/about/**/*.md
docs/agents/**/*.md
docs/agent-sdk/**/*.md
docs/agent-training/**/*.md
docs/apps/**/*.md
docs/archive/**/*.md
docs/architecture/**/*.md
docs/backend/**/*.md
docs/blockchain/**/*.md
docs/cli/**/*.md
docs/contracts/**/*.md
docs/deployment/**/*.md
docs/development/**/*.md
docs/enterprise/**/*.md
docs/guides/**/*.md
docs/infrastructure/**/*.md
docs/mining/**/*.md
docs/hermes/**/*.md
docs/packages/**/*.md
docs/reference/**/*.md
docs/releases/**/*.md
docs/reports/**/*.md
docs/scenarios/**/*.md
docs/security/**/*.md
docs/testing/**/*.md
docs/workflows/**/*.md
)
if [[ ${#targets[@]} -eq 0 ]]; then
echo "⚠️ No curated Markdown targets matched"
else
echo "Curated advisory scope: ${#targets[@]} Markdown files"
echo "Included the docs home, about hub, learning paths, and the top-level operational hubs added during remediation"
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 "${{ env.WORKSPACE_BASE }}/docs-validation/repo"
echo "=== Documentation Structure ==="
required_files=(
docs/README.md
docs/MASTER_INDEX.md
docs/about/README.md
docs/agents/README.md
docs/agent-sdk/README.md
docs/agent-training/README.md
docs/apps/README.md
docs/archive/README.md
docs/architecture/README.md
docs/backend/README.md
docs/blockchain/README.md
docs/cli/README.md
docs/contracts/README.md
docs/deployment/README.md
docs/development/README.md
docs/enterprise/README.md
docs/guides/README.md
docs/infrastructure/README.md
docs/mining/README.md
docs/hermes/README.md
docs/packages/README.md
docs/reference/README.md
docs/releases/README.md
docs/reports/README.md
docs/scenarios/README.md
docs/security/README.md
docs/testing/README.md
docs/workflows/README.md
)
for f in "${required_files[@]}"; do
if [[ -f "$f" ]]; then
echo " $f exists"
else
echo " ❌ $f missing"
exit 1
fi
done
- name: Validate master index structure
run: |
cd "${{ env.WORKSPACE_BASE }}/docs-validation/repo"
echo "=== Master Index Structure ==="
master_index_markers=(
"## 📦 **Applications Documentation**"
"## 🏠 **Main Documentation**"
"## 🔗 **External Documentation (Symlinks)**"
"## 🎯 **Topic-Specific Areas**"
)
for marker in "${master_index_markers[@]}"; do
if ! grep -qF "$marker" docs/MASTER_INDEX.md; then
echo " ❌ docs/MASTER_INDEX.md missing required marker: $marker"
exit 1
fi
done
echo "✅ Master index structure validated"
- name: Validate priority docs metadata
run: |
cd "${{ env.WORKSPACE_BASE }}/docs-validation/repo"
echo "=== Priority Documentation Metadata ==="
priority_docs=(
docs/README.md
docs/about/README.md
docs/agent-sdk/README.md
docs/blockchain/README.md
docs/apps/README.md
docs/cli/README.md
docs/testing/README.md
)
required_markers=(
"## 🧭 **Navigation Path:**"
"## 🎯 **See Also:**"
"**Level**:"
"**Prerequisites**:"
"**Estimated Time**:"
"**Last Updated**:"
"**Version**:"
)
for f in "${priority_docs[@]}"; do
if [[ ! -f "$f" ]]; then
echo " ❌ $f missing"
exit 1
fi
for marker in "${required_markers[@]}"; do
if ! grep -qF "$marker" "$f"; then
echo " ❌ $f missing required marker: $marker"
exit 1
fi
done
done
echo "✅ Priority documentation metadata validated"
- name: Documentation stats
if: always()
run: |
cd "${{ env.WORKSPACE_BASE }}/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 "${{ env.WORKSPACE_BASE }}/docs-validation"
validate-policies-strict:
runs-on: debian
timeout-minutes: 10
steps:
- name: Clone repository
run: |
WORKSPACE="${{ env.WORKSPACE_BASE }}/docs-validation-policies"
rm -rf "$WORKSPACE"
mkdir -p "$WORKSPACE"
cd "$WORKSPACE"
git clone --depth 1 "${{ env.REPO_URL }}" repo
- name: Initialize job logging
run: |
cd "${{ env.WORKSPACE_BASE }}/docs-validation-policies/repo"
bash scripts/ci/setup-job-logging.sh
- name: Ensure standard directories
run: mkdir -p ${{ env.STANDARD_DIRS }}
- name: Install markdownlint
run: |
npm install -g markdownlint-cli
- name: Strict lint policy docs
run: |
cd "${{ env.WORKSPACE_BASE }}/docs-validation-policies/repo"
shopt -s globstar nullglob
mapfile -t targets < <(printf '%s\n' docs/policies/*.md docs/policies/**/*.md | awk '!seen[$0]++')
if [[ ${#targets[@]} -eq 0 ]]; then
echo "❌ No policy Markdown files found"
exit 1
fi
echo "Strict docs scope: ${#targets[@]} policy Markdown files"
markdownlint "${targets[@]}"
echo "✅ Policy docs lint passed"
- name: Cleanup
if: always()
run: rm -rf "${{ env.WORKSPACE_BASE }}/docs-validation-policies"