Merge pull request '修改初始配置文件 适配gitea[AC-INIT]' (#9) from setup-gate into main

Reviewed-on: MerCry/ai-robot#9
This commit is contained in:
MerCry 2026-02-24 02:44:31 +00:00
commit 6ad817f190
1 changed files with 40 additions and 31 deletions

View File

@ -1,4 +1,4 @@
name: PR Check (SDD Contract Gate) name: PR Check (SDD Full Gate)
on: on:
pull_request: pull_request:
@ -8,71 +8,80 @@ on:
- 'scripts/**' - 'scripts/**'
- 'spec/**' - 'spec/**'
- 'src/**' - 'src/**'
- 'test/**'
jobs: jobs:
contract-level-check: sdd-full-gate:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout code (no GitHub dependency) - name: Checkout code (no GitHub dependency)
shell: sh shell: sh
run: | run: |
set -eu set -eu
# Try GITHUB_ vars first (Gitea usually provides these for compatibility)
# Fallback to GITEA_ vars if GITHUB_ ones are empty
SERVER_URL="${GITHUB_SERVER_URL:-${GITEA_SERVER_URL:-}}" SERVER_URL="${GITHUB_SERVER_URL:-${GITEA_SERVER_URL:-}}"
REPO_NAME="${GITHUB_REPOSITORY:-${GITEA_REPOSITORY:-}}" REPO_NAME="${GITHUB_REPOSITORY:-${GITEA_REPOSITORY:-}}"
COMMIT_SHA="${GITHUB_SHA:-${GITEA_SHA:-}}" COMMIT_SHA="${GITHUB_SHA:-${GITEA_SHA:-}}"
# If still empty, try to detect from environment # Try to get URL from git remote if env vars are missing
if [ -z "$SERVER_URL" ] || [ -z "$REPO_NAME" ] || [ -z "$COMMIT_SHA" ]; then if [ -z "$SERVER_URL" ] || [ -z "$REPO_NAME" ]; then
echo "Warning: Some standard env vars are missing. Printing environment for debugging (excluding secrets)..." echo "Warning: Env vars missing, attempting to detect from remote..."
env | grep -E "GITEA|GITHUB|CI" | sort
fi fi
# Final validation
: "${SERVER_URL:?Could not determine SERVER_URL}"
: "${REPO_NAME:?Could not determine REPO_NAME}"
: "${COMMIT_SHA:?Could not determine COMMIT_SHA}"
echo "Using SERVER_URL=$SERVER_URL" echo "Using SERVER_URL=$SERVER_URL"
echo "Using REPO_NAME=$REPO_NAME" echo "Using REPO_NAME=$REPO_NAME"
echo "Using COMMIT_SHA=$COMMIT_SHA" echo "Using COMMIT_SHA=$COMMIT_SHA"
# Clone using the determined URL (assuming no auth required for internal runner or handled by runner)
git clone "$SERVER_URL/$REPO_NAME.git" . git clone "$SERVER_URL/$REPO_NAME.git" .
git fetch origin main:main
git checkout "$COMMIT_SHA" git checkout "$COMMIT_SHA"
- name: Run OpenAPI Contract Level Check - name: 1. OpenAPI Contract Level Check
env: env:
# For PRs targeting main, enforce provider >= L2
REQUIRE_PROVIDER_L2: "1" REQUIRE_PROVIDER_L2: "1"
shell: sh shell: sh
run: | run: |
set -eu chmod +x scripts/*.sh
chmod +x scripts/check-openapi-level.sh
./scripts/check-openapi-level.sh ./scripts/check-openapi-level.sh
- name: 2. AC Traceability Check
shell: sh
run: ./scripts/check-traceability.sh
- name: 3. OpenAPI Breaking Change Check
shell: sh
run: ./scripts/check-openapi-diff.sh
- name: 4. Minimum Self-Test (mvn test)
shell: sh
run: |
# 针对 Java Spring 项目运行最小单测 (方案 B: 不存在则提示跳过)
if command -v mvn >/dev/null 2>&1; then
# 处理本地 jar 依赖:如果 lib 目录下存在 jar 包,先安装到本地仓库
if [ -f "lib/commons-codec-1.9.jar" ]; then
echo "Installing local jar: lib/commons-codec-1.9.jar"
mvn -q install:install-file \
-Dfile=lib/commons-codec-1.9.jar \
-DgroupId=commons-codec \
-DartifactId=commons-codec \
-Dversion=1.9 \
-Dpackaging=jar \
-DgeneratePom=true
fi
mvn -q -DskipTests=false test
else
echo "Warning: mvn not found, skipping unit tests. Please ensure Runner has JDK/Maven for full enforcement."
fi
- name: YAML Parse Check (Optional) - name: YAML Parse Check (Optional)
shell: sh shell: sh
run: | run: |
set -eu
if command -v python3 >/dev/null 2>&1; then if command -v python3 >/dev/null 2>&1; then
python3 -c "import sys; print('python3:', sys.version.split()[0])"
# Try to install pyyaml if missing
if ! python3 -c "import yaml" 2>/dev/null; then if ! python3 -c "import yaml" 2>/dev/null; then
echo "PyYAML missing, attempting to install..."
python3 -m pip install pyyaml --user >/dev/null 2>&1 || true python3 -m pip install pyyaml --user >/dev/null 2>&1 || true
fi fi
# Check again and run if available
if python3 -c "import yaml" 2>/dev/null; then if python3 -c "import yaml" 2>/dev/null; then
find spec -name "*.yaml" -o -name "*.yml" | xargs -I {} python3 -c "import yaml; yaml.safe_load(open('{}'))" find spec -name "*.yaml" -o -name "*.yml" | xargs -I {} python3 -c "import yaml; yaml.safe_load(open('{}'))"
echo "YAML check passed." echo "YAML check passed."
else
echo "PyYAML still missing; skipping YAML parse check."
fi fi
else
echo "python3 not available; skip YAML parse check"
fi fi