192 lines
7.3 KiB
YAML
192 lines
7.3 KiB
YAML
name: JSON Data Validation
|
|
|
|
on:
|
|
pull_request_target:
|
|
types: [opened, synchronize, reopened, edited]
|
|
branches:
|
|
- main
|
|
paths:
|
|
- 'repo/pathing/**/*.json'
|
|
workflow_dispatch:
|
|
inputs:
|
|
path:
|
|
description: '要验证的路径'
|
|
required: true
|
|
default: 'repo/pathing'
|
|
type: string
|
|
auto_fix:
|
|
description: '是否自动修复问题'
|
|
required: false
|
|
default: true
|
|
type: boolean
|
|
pr_number:
|
|
description: '关联的 PR 号'
|
|
required: false
|
|
type: string
|
|
|
|
jobs:
|
|
validate-json:
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: write
|
|
pull-requests: write
|
|
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
ref: ${{ github.event.pull_request.head.sha || github.sha }}
|
|
token: ${{ secrets.GITHUB_TOKEN }}
|
|
repository: ${{ github.event.pull_request.head.repo.full_name || github.repository }}
|
|
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: '3.10'
|
|
|
|
- name: Install dependencies
|
|
run: |
|
|
pip install packaging semver
|
|
|
|
- name: Debug file structure
|
|
run: |
|
|
echo "Current directory: $(pwd)"
|
|
echo "List files in root:"
|
|
ls -la
|
|
echo "List files in build directory (if exists):"
|
|
if [ -d "build" ]; then
|
|
ls -la build/
|
|
else
|
|
echo "build directory does not exist"
|
|
mkdir -p build
|
|
fi
|
|
|
|
- name: Setup Git
|
|
run: |
|
|
git config --global user.name "GitHub Actions Bot"
|
|
git config --global user.email "actions@github.com"
|
|
|
|
- name: Get PR information
|
|
if: ${{ github.event_name == 'workflow_dispatch' && github.event.inputs.pr_number != '' }}
|
|
id: pr_info
|
|
uses: actions/github-script@v6
|
|
with:
|
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
|
script: |
|
|
try {
|
|
const pr = await github.rest.pulls.get({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
pull_number: parseInt(${{ github.event.inputs.pr_number }})
|
|
});
|
|
|
|
core.setOutput('head_sha', pr.data.head.sha);
|
|
core.setOutput('head_ref', pr.data.head.ref);
|
|
core.setOutput('head_repo', pr.data.head.repo.full_name);
|
|
core.setOutput('found', 'true');
|
|
|
|
console.log(`找到 PR #${{ github.event.inputs.pr_number }}`);
|
|
console.log(`Head SHA: ${pr.data.head.sha}`);
|
|
console.log(`Head Ref: ${pr.data.head.ref}`);
|
|
console.log(`Head Repo: ${pr.data.head.repo.full_name}`);
|
|
} catch (error) {
|
|
console.log(`获取 PR #${{ github.event.inputs.pr_number }} 信息失败: ${error.message}`);
|
|
core.setOutput('found', 'false');
|
|
}
|
|
|
|
- name: Get changed files
|
|
id: changed_files
|
|
if: github.event_name == 'pull_request_target'
|
|
run: |
|
|
CHANGED_FILES=$(git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ github.event.pull_request.head.sha }} | grep -E '^repo/pathing/.*\.json$' || true)
|
|
echo "Changed JSON files in repo/pathing:"
|
|
echo "$CHANGED_FILES"
|
|
echo "changed_files=$CHANGED_FILES" >> $GITHUB_OUTPUT
|
|
|
|
if [ -z "$CHANGED_FILES" ]; then
|
|
echo "No JSON files changed in repo/pathing directory"
|
|
fi
|
|
|
|
- name: Run validation and correction
|
|
env:
|
|
GITHUB_ACTOR: ${{ github.actor }}
|
|
PR_NUMBER: ${{ github.event.pull_request.number || github.event.inputs.pr_number }}
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
HEAD_REF: ${{ github.event.pull_request.head.ref || steps.pr_info.outputs.head_ref || '' }}
|
|
PR_REPO: ${{ github.event.pull_request.head.repo.full_name || steps.pr_info.outputs.head_repo || github.repository }}
|
|
VALIDATE_PATH: ${{ github.event.inputs.path || 'repo/pathing' }}
|
|
AUTO_FIX: ${{ github.event.inputs.auto_fix || 'true' }}
|
|
CHANGED_FILES: ${{ steps.changed_files.outputs.changed_files }}
|
|
run: |
|
|
# 根据触发方式决定验证路径和是否自动修复
|
|
if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then
|
|
echo "手动触发模式,验证路径: ${VALIDATE_PATH}"
|
|
python build/validate.py ${VALIDATE_PATH} $([[ "${AUTO_FIX}" == "true" ]] && echo "--fix")
|
|
else
|
|
echo "PR 触发模式,仅验证修改的 JSON 文件"
|
|
if [ -z "$CHANGED_FILES" ]; then
|
|
echo "没有找到修改的 JSON 文件,跳过验证"
|
|
exit 0
|
|
fi
|
|
|
|
# 单独验证每个修改的文件
|
|
for file in $CHANGED_FILES; do
|
|
echo "验证文件: $file"
|
|
python build/validate.py "$file" --fix
|
|
done
|
|
fi
|
|
|
|
# 检查是否有文件被修改
|
|
if [ -n "$(git status --porcelain)" ]; then
|
|
echo "发现修改,提交更改"
|
|
git add .
|
|
git commit -m "自动修复 JSON 格式和版本号 [ci skip]"
|
|
git push
|
|
else
|
|
echo "没有文件被修改,无需提交"
|
|
fi
|
|
|
|
- name: Add PR comment
|
|
if: ${{ github.event_name == 'pull_request_target' || (github.event_name == 'workflow_dispatch' && github.event.inputs.pr_number != '' && steps.pr_info.outputs.found == 'true') }}
|
|
continue-on-error: true
|
|
uses: actions/github-script@v6
|
|
with:
|
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
|
script: |
|
|
const fs = require('fs');
|
|
const pr_number = ${{ github.event.pull_request.number || github.event.inputs.pr_number }};
|
|
|
|
if (fs.existsSync('validation_notes.md')) {
|
|
const message = fs.readFileSync('validation_notes.md', 'utf8');
|
|
await github.rest.issues.createComment({
|
|
issue_number: pr_number,
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
body: message
|
|
});
|
|
} else {
|
|
console.log("没有发现 validation_notes.md 文件");
|
|
|
|
// 检查是否有文件被修改并提交
|
|
const { execSync } = require('child_process');
|
|
let commitMessage = '';
|
|
|
|
try {
|
|
const lastCommit = execSync('git log -1 --pretty=%B').toString().trim();
|
|
if (lastCommit.includes('自动修复')) {
|
|
commitMessage = '✅ 校验完成并自动修复了一些问题。修改已提交到PR中。';
|
|
} else {
|
|
commitMessage = '✅ 校验完成,没有发现需要修复的问题';
|
|
}
|
|
} catch (error) {
|
|
commitMessage = '✅ 校验完成,没有发现需要修复的问题';
|
|
}
|
|
|
|
await github.rest.issues.createComment({
|
|
issue_number: pr_number,
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
body: commitMessage
|
|
});
|
|
} |