Skip to content

Commit

Permalink
Update php.yml
Browse files Browse the repository at this point in the history
Signed-off-by: ArchBlood <[email protected]>
  • Loading branch information
ArchBlood authored Oct 25, 2024
1 parent 664200c commit 7fa5f12
Showing 1 changed file with 12 additions and 34 deletions.
46 changes: 12 additions & 34 deletions .github/workflows/php.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,37 +11,8 @@ permissions:
pull-requests: write

jobs:
# Job for handling push events
push-build:
if: github.event_name == 'push'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0
token: ${{ secrets.GITHUB_TOKEN }}

- name: Setup PHP
uses: shivammathur/[email protected]
with:
php-version: '8.2'

- name: Cache Composer packages
id: composer-cache
uses: actions/cache@v3
with:
path: vendor
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }}
restore-keys: |
${{ runner.os }}-php-
- name: Install dependencies
run: |
composer install --prefer-dist --no-progress
# Job for handling pull request events
pr-build:
if: github.event_name == 'pull_request'
# Job to handle both push and pull request events
composer-build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
Expand All @@ -60,18 +31,22 @@ jobs:
echo "Head ref: ${{ github.head_ref }}"
echo "Base ref: ${{ github.base_ref }}"
# Step for fetching branch data only for pull_request events
- name: Fetch branch data for pull request
if: ${{ github.event_name == 'pull_request' }}
run: |
git fetch origin ${{ github.event.pull_request.base.ref }}
echo "Base branch for PR is: ${{ github.event.pull_request.base.ref }}"
echo "Head branch for PR is: ${{ github.head_ref }}"
- name: Check for composer.json changes
id: check-changes
if: ${{ github.event_name == 'pull_request' }}
run: |
git diff --name-only origin/${{ github.event.pull_request.base.ref }} HEAD | grep -q "^composer.json$" && echo "changed=true" >> $GITHUB_OUTPUT || echo "changed=false" >> $GITHUB_OUTPUT
- name: Output check-changes result
if: ${{ github.event_name == 'pull_request' }}
run: |
echo "composer.json change detected: ${{ steps.check-changes.outputs.changed }}"
Expand All @@ -84,19 +59,22 @@ jobs:
restore-keys: |
${{ runner.os }}-php-
# Conditional update of dependencies if composer.json changes in PR
- name: Update dependencies in PR
if: steps.check-changes.outputs.changed == 'true'
if: ${{ github.event_name == 'pull_request' && steps.check-changes.outputs.changed == 'true' }}
run: |
echo "Running composer update because composer.json changed"
composer update --prefer-dist --no-progress
# Install dependencies for both push and pull requests if no changes to composer.json
- name: Install dependencies
if: steps.check-changes.outputs.changed != 'true'
if: ${{ github.event_name == 'push' || (github.event_name == 'pull_request' && steps.check-changes.outputs.changed != 'true') }}
run: |
composer install --prefer-dist --no-progress
# Commit and push updated lock file if composer.json was changed in PR
- name: Commit and push updated lock file
if: steps.check-changes.outputs.changed == 'true'
if: ${{ github.event_name == 'pull_request' && steps.check-changes.outputs.changed == 'true' }}
run: |
if git diff --exit-code composer.lock; then
echo "No changes to composer.lock needed"
Expand Down

0 comments on commit 7fa5f12

Please sign in to comment.