Skip to content

Commit

Permalink
CI: switch to GitHub Actions - step 1: code style
Browse files Browse the repository at this point in the history
This commit:
* Adds a GH Actions workflow for the CI code style check and to validate the `composer.json` file.
* Removes those actions from the `.travis.yml` configuration.
* Adds the new `.github` directory to the `.gitattributes` file to be `export-ignore`d.
* Adds a "Build Status" badge in the Readme to use the results from this particular GH Actions run.

Notes:
1. Builds will run on all pushes and on pull requests.
2. Builds can also be manually triggered.
    Note: manual triggering of builds has to be [explicitly allowed](https://github.blog/changelog/2020-07-06-github-actions-manual-triggers-with-workflow_dispatch/). This is not a feature which is enabled by default.
3. Composer dependency downloads will be cached for faster builds using a [predefined GH action](https://github.com/marketplace/actions/install-composer-dependencies) specifically created for this purpose.
    The alternative would be to handle the caching manually, which would add three extra steps to the script.
    Note: Caching works differently between Travis and GH Actions.
    On GH Actions, once a cache has been created, it can't be updated. It can only be replaced by a new cache with a different key.
    As the PHP version, the `composer.json` and a potential `composer.lock` hash are all part of the key used by the above mentioned action, this difference should not have a significant impact.
    Ref: https://docs.github.com/en/actions/advanced-guides/caching-dependencies-to-speed-up-workflows
4. The CS check will display the results in the actions script output log, as well as display any violations found inline in the GitHub code view using the [cs2pr](https://github.com/staabm/annotate-pull-request-from-checkstyle) tool.

 Differences with the Travis implementation:
* The `composer validate` command will now only be run against the PHP version used in the `cs` script (PHP 7.4), not against multiple PHP versions.
  • Loading branch information
jrfnl committed Oct 2, 2021
1 parent bd8caaf commit d2e4bca
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 4 deletions.
1 change: 1 addition & 0 deletions .gitattributes
Expand Up @@ -15,6 +15,7 @@
/phpunit.xml export-ignore
/phpunit.xml.dist export-ignore
/.cache export-ignore
/.github export-ignore
/images export-ignore
/tests export-ignore

Expand Down
44 changes: 44 additions & 0 deletions .github/workflows/cs.yml
@@ -0,0 +1,44 @@
name: CS

on:
# Run on all pushes and on all pull requests.
push:
pull_request:
# Allow manually triggering the workflow.
workflow_dispatch:

jobs:
checkcs:
name: 'Check code style'
runs-on: ubuntu-latest

steps:
- name: Checkout code
uses: actions/checkout@v2

- name: Install PHP
uses: shivammathur/setup-php@v2
with:
php-version: '7.4'
coverage: none
tools: cs2pr

# Validate the composer.json file.
# @link https://getcomposer.org/doc/03-cli.md#validate
- name: Validate Composer installation
run: composer validate --no-check-all

# Install dependencies and handle caching in one go.
# @link https://github.com/marketplace/actions/install-composer-dependencies
- name: Install Composer dependencies
uses: ramsey/composer-install@v1

# Check the codestyle of the files within YoastCS.
# The results of the CS check will be shown inline in the PR via the CS2PR tool.
# @link https://github.com/staabm/annotate-pull-request-from-checkstyle/
- name: Check PHP code style
continue-on-error: true
run: composer check-cs -- --report-full --report-checkstyle=./phpcs-report.xml

- name: Show PHPCS results in PR
run: cs2pr ./phpcs-report.xml
5 changes: 1 addition & 4 deletions .travis.yml
Expand Up @@ -12,15 +12,14 @@ cache:

php:
- 8.0
- 7.4
- 7.3
- 7.2
- 7.1

jobs:
fast_finish: true
include:
- php: 7.4
env: PHPCS=1
- php: 7.0
dist: xenial
- php: 5.6
Expand Down Expand Up @@ -50,5 +49,3 @@ script:
- echo $TRAVIS_PHP_VERSION
- composer lint
- ./vendor/bin/phpunit
- if [[ "$TRAVIS_PHP_VERSION" == "5.3" || "$TRAVIS_PHP_VERSION" == "7.4" ]]; then composer validate --no-check-all; fi
- if [[ $PHPCS == "1" ]]; then composer check-cs; fi
2 changes: 2 additions & 0 deletions README.md
@@ -1,3 +1,5 @@
[![CS](https://github.com/Yoast/whip/actions/workflows/cs.yml/badge.svg)](https://github.com/Yoast/whip/actions/workflows/cs.yml)

# whip
A WordPress package to nudge users to upgrade their software versions (starting with PHP)

Expand Down

0 comments on commit d2e4bca

Please sign in to comment.