mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-12 10:31:26 +02:00
Update onpush_builder.yaml
This commit is contained in:
49
.github/workflows/onpush_builder.yaml
vendored
49
.github/workflows/onpush_builder.yaml
vendored
@@ -16,34 +16,25 @@ env:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
# 1. Detect which add-on folders changed (by config.json|yaml|yml modification)
|
# 1. Detect which add-on folders changed (by config.json|yaml|yml modification)
|
||||||
detect-changed-addons:
|
detect-changed-addons:
|
||||||
if: ${{ github.repository_owner == 'alexbelgium' && !contains(github.event.head_commit.message, 'nobuild') }}
|
if: ${{ github.repository_owner == 'alexbelgium' && !contains(github.event.head_commit.message, 'nobuild') }}
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
outputs:
|
outputs:
|
||||||
changedAddons: ${{ steps.find_addons.outputs.changed_addons }}
|
changedAddons: ${{ steps.find_addons.outputs.changed_addons }}
|
||||||
steps:
|
dockerfile_exists: ${{ steps.dockerfile_check.outputs.dockerfile_exists }}
|
||||||
- name: Checkout repo
|
steps:
|
||||||
uses: actions/checkout@v4
|
- name: Checkout repo
|
||||||
- name: Find changed addon directories
|
uses: actions/checkout@v4
|
||||||
id: find_addons
|
- name: Find changed addon directories
|
||||||
run: |
|
id: find_addons
|
||||||
git fetch origin "${{ github.event.before }}" || true
|
run: |
|
||||||
changed_config_files=$(git diff --name-only "${{ github.event.before }}" "${{ github.sha }}" | grep -E '^[^/]+/config\.(json|ya?ml)$' || true)
|
git fetch origin "${{ github.event.before }}" || true
|
||||||
echo "Changed config files:"
|
changed_config_files=$(git diff --name-only "${{ github.event.before }}" "${{ github.sha }}" | grep -E '^[^/]+/config\.(json|ya?ml)$' || true)
|
||||||
echo "$changed_config_files"
|
echo "Changed config files:"
|
||||||
changed_addons=$(echo "$changed_config_files" | awk -F/ '{print $1}' | sort -u | jq -R -s -c 'split("\n")[:-1]')
|
echo "$changed_config_files"
|
||||||
echo "Changed addons: $changed_addons"
|
changed_addons=$(echo "$changed_config_files" | awk -F/ '{print $1}' | sort -u | jq -R -s -c 'split("\n")[:-1]')
|
||||||
echo "changed_addons=$changed_addons" >> "$GITHUB_OUTPUT"
|
echo "Changed addons: $changed_addons"
|
||||||
- name: Check for Dockerfile (case-insensitive)
|
echo "changed_addons=$changed_addons" >> "$GITHUB_OUTPUT"
|
||||||
id: dockerfile_check
|
|
||||||
run: |
|
|
||||||
cd "${{ matrix.addon }}"
|
|
||||||
if find . -maxdepth 1 -type f -iname "dockerfile" | grep -q .; then
|
|
||||||
echo "dockerfile_exists=true" >> "$GITHUB_OUTPUT"
|
|
||||||
else
|
|
||||||
echo "No Dockerfile found in ${{ matrix.addon }}, skipping build"
|
|
||||||
echo "dockerfile_exists=false" >> "$GITHUB_OUTPUT"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# 2. Pre-build sanitize: normalize spaces, fix script permissions, single commit per add-on
|
# 2. Pre-build sanitize: normalize spaces, fix script permissions, single commit per add-on
|
||||||
prebuild-sanitize:
|
prebuild-sanitize:
|
||||||
@@ -99,7 +90,7 @@ jobs:
|
|||||||
|
|
||||||
# 4. Build images for changed addons/arches
|
# 4. Build images for changed addons/arches
|
||||||
build:
|
build:
|
||||||
if: ${{ needs.detect-changed-addons.outputs.changedAddons != '' && needs.detect-changed-addons.outputs.changedAddons != '[]' && steps.dockerfile_check.outputs.dockerfile_exists == 'true' }}
|
if: ${{ needs.detect-changed-addons.outputs.changedAddons != '' && needs.detect-changed-addons.outputs.changedAddons != '[]' }}
|
||||||
needs: [detect-changed-addons, lint_config]
|
needs: [detect-changed-addons, lint_config]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
environment: CR_PAT
|
environment: CR_PAT
|
||||||
|
|||||||
Reference in New Issue
Block a user