Skip to content

Commit

Permalink
Merge pull request #185 from IanCa/main
Browse files Browse the repository at this point in the history
Add script to auto update schemas, move code to hed-python
  • Loading branch information
VisLab authored May 20, 2024
2 parents 36ca73d + d154f6a commit 3026003
Show file tree
Hide file tree
Showing 3 changed files with 90 additions and 57 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/check_schemas.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -42,4 +42,4 @@ jobs:
env:
ALL_CHANGED_FILES: ${{ steps.changed-files.outputs.all_changed_files }}
run: |
python tests/validate_schemas.py $ALL_CHANGED_FILES
hed_validate_schemas $ALL_CHANGED_FILES
89 changes: 89 additions & 0 deletions .github/workflows/update_and_convert_schemas.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
name: Validate and update schemas

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

jobs:
process-changed-files:
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 }}
56 changes: 0 additions & 56 deletions tests/validate_schemas.py

This file was deleted.

0 comments on commit 3026003

Please sign in to comment.