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: Static Code Analysis | |
on: | |
- pull_request | |
- push | |
permissions: | |
contents: read # to fetch code (actions/checkout) | |
concurrency: | |
group: sca-${{ github.head_ref || github.run_id }} # will be canceled on subsequent pushes in pull requests but not branches | |
cancel-in-progress: true | |
jobs: | |
tests: | |
strategy: | |
fail-fast: false | |
matrix: | |
operating-system: | |
- ubuntu-20.04 | |
php-version: | |
- 8.3 | |
name: Static Code Analysis | |
runs-on: ${{ matrix.operating-system }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
# We need to fetch base branch because `actions/checkout` only initializes empty repo and fetches PR's meta-branch | |
# which leads to `fatal: ambiguous argument 'origin/...': unknown revision or path not in the working tree.`, | |
# because of that `CHANGED_PHP_FILES` is not set, and tools based on diff between branches (like Mess Detector) don't work. | |
- name: Fetch base branch | |
if: ${{ github.event_name == 'pull_request' }} | |
run: git fetch --no-tags --prune --no-recurse-submodules --depth=1 origin $GITHUB_BASE_REF | |
- name: Setup PHP with Composer deps | |
uses: ./.github/composite-actions/setup-php-with-composer-deps | |
with: | |
os: ${{ runner.os }} | |
php: ${{ matrix.php-version }} | |
## We want to have a lock-file used on PR level, so contributors are not bothered by SCA complains unrelated to their changes, | |
## and same time we want to be aware that we are complying with bleeding edge of SCA tools as maintainers observing the push hook. | |
- name: Unlock dev-tools | |
if: ${{ github.event_name != 'pull_request' }} | |
run: rm ./dev-tools/composer.lock | |
- name: Cache dev-tools | |
uses: actions/cache@v4 | |
with: | |
path: dev-tools/bin/ | |
key: DevTools-${{ hashFiles('dev-tools/install.sh') }} | |
- name: Install dev-tools | |
uses: nick-invision/retry@v3 | |
with: | |
timeout_minutes: 5 | |
max_attempts: 5 | |
retry_wait_seconds: 30 | |
command: ./dev-tools/install.sh | |
- name: Show PHPUnit version | |
run: vendor/bin/phpunit --version | |
- name: Run AutoReview | |
run: vendor/bin/paraunit run --testsuite auto-review | |
- name: Check - file permissions | |
run: ./dev-tools/check_file_permissions.sh | |
- name: Check - trailing spaces | |
run: ./dev-tools/check_trailing_spaces.sh | |
- name: Check - phpstan | |
run: ./dev-tools/vendor/bin/phpstan analyse --ansi | |
- name: Check - composer-unused | |
run: ./dev-tools/vendor/bin/composer-unused --no-progress --excludePackage=composer/xdebug-handler | |
- name: Check - composer-require-checker | |
run: ./dev-tools/vendor/bin/composer-require-checker check composer.json --config-file .composer-require-checker.json | |
- name: Check - composer normalize | |
run: | | |
composer normalize --dry-run --working-dir=./dev-tools ../composer.json | |
composer normalize --dry-run --working-dir=./dev-tools composer.json | |
- name: Check - shell scripts | |
run: ./dev-tools/check_shell_scripts.sh | |
- name: Find changed files (for pull request) | |
if: ${{ github.event_name == 'pull_request' }} | |
run: | | |
if git diff origin/$GITHUB_BASE_REF --name-only --diff-filter=ACMRTUXB | grep -E "\.php$"; then | |
echo 'CHANGED_PHP_FILES<<EOF' >> $GITHUB_ENV | |
git diff origin/$GITHUB_BASE_REF --name-only --diff-filter=ACMRTUXB | grep -E "\.php$" >> $GITHUB_ENV | |
echo 'EOF' >> $GITHUB_ENV | |
fi | |
- name: Find changed files (for push) | |
if: ${{ github.event_name != 'pull_request' }} | |
run: | | |
if git diff --name-only --diff-filter=ACMRTUXB HEAD~..HEAD | grep -E "\.php$"; then | |
echo 'CHANGED_PHP_FILES<<EOF' >> $GITHUB_ENV | |
git diff --name-only --diff-filter=ACMRTUXB HEAD~..HEAD | grep -E "\.php$" >> $GITHUB_ENV | |
echo 'EOF' >> $GITHUB_ENV | |
fi | |
- name: Check - well defined array keys | |
if: ${{ env.CHANGED_PHP_FILES }} | |
run: | | |
echo "Array types must explicitly declare key-type, i.e. as \`array<type-of-key, type-of-value>\`, \`list<type-of-value>\` or \`array{...}\` - instead of \`array<type-of-value>\` or \`type-of-value[]\`." | |
echo "Hint: don't apply those rules blindly, provide array key type explicitly\!" | |
./php-cs-fixer check --config=dev-tools/.php-cs-fixer.well-defined-arrays.php --path-mode=intersection $CHANGED_PHP_FILES | |
- name: Check - Mess Detector (phpmd) | |
if: ${{ env.CHANGED_PHP_FILES }} | |
run: | | |
if [ '${{ github.event_name }}' == 'pull_request' ]; then | |
./dev-tools/vendor/bin/phpmd `echo "$CHANGED_PHP_FILES" | grep -v /Fixtures/ | xargs | sed 's/ /,/g'` github ./dev-tools/mess-detector/phpmd.xml | |
else | |
./dev-tools/vendor/bin/phpmd `echo "$CHANGED_PHP_FILES" | grep -v /Fixtures/ | xargs | sed 's/ /,/g'` ansi ./dev-tools/mess-detector/phpmd.xml | |
fi | |
- name: Check - ensure test files are not present in the archive | |
run: | | |
git archive -o /dev/null HEAD -v 2>&1 | grep tests | grep \.php \ | |
&& (echo "Test files detected in archive" && exit 1) || echo "No test files detected in archive" |