Added new workflow to check files in the migrations folder #26
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Flyway Migration Files | |
on: | |
pull_request: | |
branches: | |
- '**' | |
jobs: | |
validate: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout current branch | |
uses: actions/checkout@v3 | |
- name: Fetch base branch | |
run: | | |
git fetch origin +refs/heads/${{ github.base_ref }}:refs/remotes/origin/${{ github.base_ref }} | |
- name: Check for new migration files | |
run: | | |
echo "Checking for new migration files..." | |
# Set the directory for migrations | |
MIGRATION_DIR=src/main/resources/db/migration | |
# Get existing migration files from the base branch | |
BASE_MIGRATION_FILES=$(git ls-tree -r --name-only origin/${{ github.base_ref }} -- $MIGRATION_DIR) | |
# Initialize variable to hold the latest base file | |
LATEST_BASE_FILE="" | |
LATEST_BASE_TIMESTAMP="" | |
# Determine the latest timestamp from the base branch | |
for BASE_FILE in $BASE_MIGRATION_FILES; do | |
BASE_TIMESTAMP=$(echo $BASE_FILE | grep -oP 'V\K[0-9_]{10,14}') | |
# Check if the timestamp is valid | |
if [[ -z "$BASE_TIMESTAMP" ]]; then | |
echo "Error: Base file $BASE_FILE does not have a valid timestamp." | |
continue | |
fi | |
# Check if this base timestamp is later than the current latest | |
if [[ "$LATEST_BASE_TIMESTAMP" < "$BASE_TIMESTAMP" ]]; then | |
LATEST_BASE_TIMESTAMP="$BASE_TIMESTAMP" | |
LATEST_BASE_FILE="$BASE_FILE" | |
fi | |
done | |
echo "Base migration file with the latest timestamp:" | |
echo "$LATEST_BASE_FILE" | |
# List current migration files | |
CURRENT_MIGRATION_FILES=$(ls $MIGRATION_DIR) | |
echo "Current migration files: $CURRENT_MIGRATION_FILES" | |
# Get the new migration files added in the current branch | |
NEW_MIGRATION_FILES=$(git diff --name-only origin/${{ github.base_ref }} -- $MIGRATION_DIR) | |
# Output new migration files found in the current branch | |
if [[ -z "$NEW_MIGRATION_FILES" ]]; then | |
echo "No new migration files found." | |
exit 0 | |
else | |
echo "New migration files in the current branch:" | |
echo "$NEW_MIGRATION_FILES" | |
fi | |
# Flag to track if there are any errors | |
ERROR_FOUND=false | |
# Check for new migration files and their timestamps | |
for FILE in $NEW_MIGRATION_FILES; do | |
TIMESTAMP=$(echo $FILE | grep -oP 'V\K[0-9_]{10,14}') | |
# Ensure the timestamp is valid | |
if [[ -z "$TIMESTAMP" ]]; then | |
echo "Error: File $FILE does not have a valid timestamp." | |
exit 1 | |
fi | |
# Validate against the latest base file timestamp | |
if [[ "$TIMESTAMP" < "$LATEST_BASE_TIMESTAMP" ]]; then | |
echo "Error: Timestamp $TIMESTAMP in $FILE is earlier than the latest base migration timestamp $LATEST_BASE_TIMESTAMP from $LATEST_BASE_FILE." | |
ERROR_FOUND=true | |
fi | |
done | |
# Exit with an error if any new files are invalid | |
if [[ "$ERROR_FOUND" == true ]]; then | |
exit 1 | |
fi | |
echo "All new migration files are valid." |