mirror of
https://github.com/StarCitizenTools/mediawiki-extensions-TabberNeue.git
synced 2024-11-27 17:50:55 +00:00
chore(ci): more robust linter
* Only run linter if there are changes * Cancel previous running workflow * Cache dependencies
This commit is contained in:
parent
e642364b6f
commit
dea326423c
96
.github/workflows/mediawiki.yml
vendored
96
.github/workflows/mediawiki.yml
vendored
|
@ -10,33 +10,91 @@ on:
|
|||
|
||||
jobs:
|
||||
test:
|
||||
name: Test and lint
|
||||
name: Lint
|
||||
runs-on: ubuntu-latest
|
||||
strategy:
|
||||
matrix:
|
||||
php-versions: ['7.4']
|
||||
steps:
|
||||
- uses: actions/checkout@v2
|
||||
|
||||
- name: Cancel Previous Runs
|
||||
uses: styfle/cancel-workflow-action@0.9.1
|
||||
with:
|
||||
access_token: ${{ github.token }}
|
||||
|
||||
- uses: actions/checkout@v3
|
||||
with:
|
||||
fetch-depth: 0 # OR "2" -> To retrieve the preceding commit.
|
||||
|
||||
- name: Cache dependencies
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: /home/runner/cache
|
||||
key: ${{ runner.os }}-${{ hashFiles('**/*.lock') }}
|
||||
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
composer validate
|
||||
npm install --save-dev
|
||||
composer install --prefer-dist --no-progress
|
||||
npm install --save-dev
|
||||
|
||||
# Check for changed files
|
||||
- name: Check for PHP changes
|
||||
id: changed-php
|
||||
uses: tj-actions/changed-files@v19
|
||||
with:
|
||||
files: |
|
||||
includes/**/*.php
|
||||
|
||||
- name: Check for script changes
|
||||
id: changed-script
|
||||
uses: tj-actions/changed-files@v19
|
||||
with:
|
||||
files: |
|
||||
resources/**/*.js
|
||||
|
||||
- name: Check for stylesheet changes
|
||||
id: changed-stylesheet
|
||||
uses: tj-actions/changed-files@v19
|
||||
with:
|
||||
files: |
|
||||
resources/**/*.css
|
||||
resources/**/*.less
|
||||
skinStyles/**/*.css
|
||||
skinStyles/**/*.less
|
||||
|
||||
- name: Check for i18n changes
|
||||
id: changed-i18n
|
||||
uses: tj-actions/changed-files@v19
|
||||
with:
|
||||
files: |
|
||||
i18n/*.json
|
||||
|
||||
# Bypass the phpcbf non-standard exit code
|
||||
- name: Check PHP
|
||||
- name: Lint PHP
|
||||
if: steps.changed-php.outputs.any_changed == 'true'
|
||||
continue-on-error: true
|
||||
run: |
|
||||
sh ./bin/phpcbf.sh
|
||||
composer fix
|
||||
composer test
|
||||
|
||||
#- name: Check Javascript
|
||||
# run: |
|
||||
# npm run lint:fix:js
|
||||
# npm run lint:js
|
||||
- name: Lint script
|
||||
if: steps.changed-script.outputs.any_changed == 'true'
|
||||
continue-on-error: true
|
||||
run: |
|
||||
npm run lint:fix:js
|
||||
npm run lint:js
|
||||
|
||||
- name: Check i18n
|
||||
- name: Lint stylesheet
|
||||
if: steps.changed-stylesheet.outputs.any_changed == 'true'
|
||||
continue-on-error: true
|
||||
run: |
|
||||
npm run lint:fix:styles
|
||||
npm run lint:styles
|
||||
|
||||
- name: Lint i18n
|
||||
if: steps.changed-i18n.outputs.any_changed == 'true'
|
||||
continue-on-error: true
|
||||
run: |
|
||||
npm run lint:i18n
|
||||
|
||||
|
@ -46,10 +104,14 @@ jobs:
|
|||
env:
|
||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
run: |
|
||||
git config --global user.name "github-actions"
|
||||
git config --global user.email "github-actions@users.noreply.github.com"
|
||||
git remote set-url origin "https://x-access-token:${GITHUB_TOKEN}@github.com/${GITHUB_REPOSITORY}.git"
|
||||
git add .
|
||||
git commit -am "ci: lint code to MediaWiki standards" -m "Check commit and GitHub actions for more details" || echo "No changes to commit"
|
||||
git pull --rebase
|
||||
git push
|
||||
if ! git diff --exit-code --quiet; then
|
||||
git config --global user.name "github-actions"
|
||||
git config --global user.email "github-actions@users.noreply.github.com"
|
||||
git remote set-url origin "https://x-access-token:${GITHUB_TOKEN}@github.com/${GITHUB_REPOSITORY}.git"
|
||||
git add .
|
||||
git commit -am "ci: lint code to MediaWiki standards" -m "Check commit and GitHub actions for more details"
|
||||
git pull --rebase
|
||||
git push
|
||||
else
|
||||
echo "No changes to commit"
|
||||
fi
|
||||
|
|
Loading…
Reference in a new issue