fix(workflow): Correct upstream sync to preserve custom files and push to stable
Fixed two critical issues in the sync-upstream.yml workflow: 1. Wildcard conflict resolution: The previous logic used wildcards (profiles/*.yml) that overlapped with custom files (profiles/*Micro*.yml), causing custom files to be overwritten. Now uses a two-phase explicit merge strategy: - Phase 1: Accept all upstream changes - Phase 2: Explicitly restore custom files by exact path 2. Wrong push target: Changed from 'main || master' to 'stable' branch This ensures weekly syncs will now work correctly while preserving: - profiles/1080p Micro.yml, 720p Micro.yml - custom_formats/Micro Encode Tier 1/2/3.yml - regex_patterns/BONE.yml, ETHEL.yml, GalaxyRG.yml, TGx.yml - custom_formats/Foreign Release Groups.yml
This commit is contained in:
parent
2478ebcc29
commit
1add4d97cf
|
|
@ -32,24 +32,51 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
# Try to merge upstream changes
|
# Try to merge upstream changes
|
||||||
git merge upstream/stable --no-edit --allow-unrelated-histories || {
|
git merge upstream/stable --no-edit --allow-unrelated-histories || {
|
||||||
echo "Merge conflict detected, attempting auto-resolution..."
|
echo "=== Merge conflict detected, applying custom merge strategy ==="
|
||||||
|
|
||||||
# Keep our custom files (Micro profiles and formats)
|
# PHASE 1: Accept ALL upstream changes first
|
||||||
git checkout --ours profiles/*Micro*.yml custom_formats/*Micro*.yml regex_patterns/BONE.yml regex_patterns/GalaxyRG.yml regex_patterns/TGx.yml regex_patterns/ETHEL.yml 2>/dev/null || true
|
echo "Phase 1: Accepting all upstream changes..."
|
||||||
|
git checkout --theirs .
|
||||||
# Keep their files for everything else
|
|
||||||
git checkout --theirs profiles/*.yml custom_formats/*.yml regex_patterns/*.yml 2>/dev/null || true
|
|
||||||
|
|
||||||
# Add resolved files
|
|
||||||
git add -A
|
git add -A
|
||||||
|
|
||||||
|
# PHASE 2: Restore our custom files explicitly
|
||||||
|
echo "Phase 2: Restoring custom files from our branch..."
|
||||||
|
|
||||||
|
CUSTOM_FILES=(
|
||||||
|
"profiles/1080p Micro.yml"
|
||||||
|
"profiles/720p Micro.yml"
|
||||||
|
"custom_formats/Micro Encode Tier 1.yml"
|
||||||
|
"custom_formats/Micro Encode Tier 2.yml"
|
||||||
|
"custom_formats/Micro Encode Tier 3.yml"
|
||||||
|
"regex_patterns/BONE.yml"
|
||||||
|
"regex_patterns/ETHEL.yml"
|
||||||
|
"regex_patterns/GalaxyRG.yml"
|
||||||
|
"regex_patterns/TGx.yml"
|
||||||
|
"custom_formats/Foreign Release Groups.yml"
|
||||||
|
)
|
||||||
|
|
||||||
|
for file in "${CUSTOM_FILES[@]}"; do
|
||||||
|
if git cat-file -e HEAD:"$file" 2>/dev/null; then
|
||||||
|
echo " ✓ Preserving: $file"
|
||||||
|
git checkout --ours "$file"
|
||||||
|
git add "$file"
|
||||||
|
else
|
||||||
|
echo " ⚠ Not found in our branch: $file"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
# Complete the merge
|
# Complete the merge
|
||||||
git commit -m "chore(sync): Merge upstream changes from Dictionarry-Hub/database" || true
|
if git diff --cached --quiet; then
|
||||||
|
echo "No changes to commit after merge resolution"
|
||||||
|
else
|
||||||
|
echo "=== Committing merge ==="
|
||||||
|
git commit -m "chore(sync): Merge upstream changes while preserving custom Micro profiles and formats"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
- name: Push changes
|
- name: Push changes
|
||||||
run: |
|
run: |
|
||||||
git push origin main || git push origin master
|
git push origin stable
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue