修改初始配置文件 适配gitea[AC-INIT]
PR Check (SDD Full Gate) / sdd-full-gate (pull_request) Failing after 2s
Details
PR Check (SDD Full Gate) / sdd-full-gate (pull_request) Failing after 2s
Details
This commit is contained in:
parent
a21444634c
commit
5133d574a4
|
|
@ -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
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue