Skip to content

Commit

Permalink
Add schema updating script
Browse files Browse the repository at this point in the history
  • Loading branch information
IanCa committed May 23, 2024
1 parent 3026003 commit 7699451
Showing 1 changed file with 50 additions and 82 deletions.
132 changes: 50 additions & 82 deletions .github/workflows/update_and_convert_schemas.yaml
Original file line number Diff line number Diff line change
@@ -1,89 +1,57 @@
name: Validate and update schemas
name: Update schemas with changes

on:
pull_request:
types: [opened, synchronize, reopened]
push:
branches: ["*"]


jobs:
process-changed-files:
check_changes:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0 # OR "2" -> To retrieve the preceding commit.
ref: ${{ github.head_ref }}

# This part might need revision. This avoids the extra merge commit.
- name: Fetch updates from the target branch
run: |
git config --global user.name 'GitHub Actions'
git config --global user.email 'actions@github.com'
git fetch origin ${{ github.event.pull_request.base.ref }}
git rebase origin/${{ github.event.pull_request.base.ref }}
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.10'

- name: Determine if branch is main
run: |
if [ "${{ github.base_ref }}" = "main" ]; then
echo "SINCE_LAST_REMOTE_COMMIT=false" >> $GITHUB_ENV
else
echo "SINCE_LAST_REMOTE_COMMIT=true" >> $GITHUB_ENV
fi
- name: Get changed files
id: changed-files
uses: tj-actions/changed-files@v41
with:
since_last_remote_commit: ${{ env.SINCE_LAST_REMOTE_COMMIT }}

- name: List all changed files
env:
ALL_CHANGED_FILES: ${{ steps.changed-files.outputs.all_changed_files }}
run: |
for file in "$ALL_CHANGED_FILES"; do
echo "$file was changed"
done
- name: Install dependencies
run: pip install git+https://github.com/hed-standard/hed-python.git@develop

- name: Update schemas
env:
ALL_CHANGED_FILES: ${{ steps.changed-files.outputs.all_changed_files }}
run: |
SOURCE_BRANCH="${{ github.head_ref }}"
TARGET_BRANCH="${{ github.base_ref }}"
echo "Source Branch: $SOURCE_BRANCH"
echo "Target Branch: $TARGET_BRANCH"
if [ "$SOURCE_BRANCH" = "develop" ] && [ "$TARGET_BRANCH" = "main" ]; then
echo "Error: Source branch 'develop' is not allowed for this operation."
exit 1
elif [ "$TARGET_BRANCH" = "main" ]; then
hed_update_schemas $ALL_CHANGED_FILES --set-ids
else
hed_update_schemas $ALL_CHANGED_FILES
fi
- name: Check for changes
id: check-changes
run: |
if ! git diff --quiet || ! git diff --cached --quiet || git ls-files --others --exclude-standard | grep -q .; then
echo "changes_exist=true" >> $GITHUB_ENV
else
echo "changes_exist=false" >> $GITHUB_ENV
fi
- name: Commit and push changes
if: env.changes_exist == 'true'
run: |
git add .
git commit -m "Automatic file updates"
git push --force-with-lease origin HEAD:refs/heads/${{ github.head_ref }}
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0 # Get complete history

- name: Get latest push changes
id: changed-files
# if: github.base_ref != 'main' && github.event.action == 'synchronize'
uses: tj-actions/changed-files@v44
with:
since_last_remote_commit: true

- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.10'

- name: List all changed files
env:
ALL_CHANGED_FILES: ${{ steps.changed-files.outputs.all_changed_files }}
run: |
for file in "$ALL_CHANGED_FILES"; do
echo "$file was changed"
done
- name: Install dependencies
run: pip install git+https://github.com/hed-standard/hed-python.git@develop

- name: Update schemas
env:
ALL_CHANGED_FILES: ${{ steps.changed-files.outputs.all_changed_files }}
run: |
hed_update_schemas $ALL_CHANGED_FILES
- name: Push schema changes
run: |
git config --global user.name 'GitHub Actions'
git config --global user.email 'actions@github.com'
git add .
if git diff --staged --quiet; then
echo "No changes to commit."
else
git commit -m "Automated schema changes"
git push
fi

0 comments on commit 7699451

Please sign in to comment.