Skip to content
Snippets Groups Projects
php.yml 6.81 KiB
Newer Older
name: CI

on:
  push:
    branches: [ '**' ]
    paths-ignore:
      - '**.md'
  pull_request:
Tim van Dijen's avatar
Tim van Dijen committed
    branches: [ master, simplesamlphp-* ]
    paths-ignore:
      - '**.md'

jobs:
  basic-tests:
    name: Syntax and unit tests, PHP ${{ matrix.php-versions }}, ${{ matrix.operating-system }}
    runs-on: ${{ matrix.operating-system }}
    strategy:
      fail-fast: false
      matrix:
        operating-system: [ubuntu-latest, windows-latest]
Tim van Dijen's avatar
Tim van Dijen committed
        php-versions: ['8.0', '8.1']

    steps:
      - name: Setup PHP, with composer and extensions
        uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
        with:
          php-version: ${{ matrix.php-versions }}
          extensions: intl, mbstring, mysql, pdo, pdo_sqlite, xml
Tim van Dijen's avatar
Tim van Dijen committed
          tools: composer:v2
          ini-values: error_reporting=E_ALL
Tim van Dijen's avatar
Tim van Dijen committed
          coverage: xdebug

      - name: Setup problem matchers for PHP
        run: echo "::add-matcher::${{ runner.tool_cache }}/php.json"

      - name: Setup problem matchers for PHPUnit
        run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json"

      - name: Set git to use LF
        run: |
          git config --global core.autocrlf false
          git config --global core.eol lf

      - uses: actions/checkout@v3

      - name: Get composer cache directory
        id: composer-cache
        run: echo "::set-output name=dir::$(composer config cache-files-dir)"

      - name: Cache composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        uses: actions/cache@v3
        with:
          path: ${{ steps.composer-cache.outputs.dir }}
          key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
          restore-keys: ${{ runner.os }}-composer-

      - name: Validate composer.json and composer.lock
        run: composer validate

      - name: Install Composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        run: composer install --no-progress --prefer-dist --optimize-autoloader

      - name: Syntax check PHP
        run: bash vendor/bin/check-syntax-php.sh

      - name: Decide whether to run code coverage or not
Tim van Dijen's avatar
Tim van Dijen committed
        if: ${{ matrix.php-versions != '8.0' || matrix.operating-system != 'ubuntu-latest' }}
        run: |
          echo "NO_COVERAGE=--no-coverage" >> $GITHUB_ENV

      - name: Run unit tests
        run: |
          echo $NO_COVERAGE
          ./vendor/bin/phpunit $NO_COVERAGE

      - name: Save coverage data
Tim van Dijen's avatar
Tim van Dijen committed
        if: ${{ matrix.php-versions == '8.0' && matrix.operating-system == 'ubuntu-latest' }}
        uses: actions/upload-artifact@v3
        with:
            name: build-data
            path: ${{ github.workspace }}/build

  security:
    name: Security checks
    runs-on: [ubuntu-latest]
    steps:
      - name: Setup PHP, with composer and extensions
        uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
        with:
Tim van Dijen's avatar
Tim van Dijen committed
            php-version: '8.0'
            extensions: mbstring, xml
Tim van Dijen's avatar
Tim van Dijen committed
            tools: composer:v2
            coverage: none

      - name: Setup problem matchers for PHP
        run: echo "::add-matcher::${{ runner.tool_cache }}/php.json"

      - uses: actions/checkout@v3

      - name: Get composer cache directory
        id: composer-cache
        run: echo "::set-output name=dir::$(composer config cache-files-dir)"

      - name: Cache composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        uses: actions/cache@v3
        with:
            path: ${{ steps.composer-cache.outputs.dir }}
            key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
            restore-keys: ${{ runner.os }}-composer-

      - name: Install Composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        run: composer install --no-progress --prefer-dist --optimize-autoloader

      - name: Security check for locked dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        uses: symfonycorp/security-checker-action@v3

      - name: Update Composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        run: composer update --no-progress --prefer-dist --optimize-autoloader

      - name: Security check for updated dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        uses: symfonycorp/security-checker-action@v3

  sanity-check:
    name: Sanity checks
    runs-on: [ubuntu-latest]

    steps:
      - name: Setup PHP, with composer and extensions
        uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
        with:
Tim van Dijen's avatar
Tim van Dijen committed
          php-version: '8.0'
          extensions: mbstring, xml
Tim van Dijen's avatar
Tim van Dijen committed
          tools: composer:v2
          coverage: none

      - name: Setup problem matchers for PHP
        run: echo "::add-matcher::${{ runner.tool_cache }}/php.json"

      - uses: actions/checkout@v3

      - name: Get composer cache directory
        id: composer-cache
        run: echo "::set-output name=dir::$(composer config cache-files-dir)"

      - name: Cache composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        uses: actions/cache@v3
        with:
            path: ${{ steps.composer-cache.outputs.dir }}
            key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
            restore-keys: ${{ runner.os }}-composer-

      - name: Install Composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        run: composer install --no-progress --prefer-dist --optimize-autoloader

      - name: Syntax check YAML / XML / JSON
        run: |
          bash vendor/bin/check-syntax-yaml.sh
          bash vendor/bin/check-syntax-xml.sh
          bash vendor/bin/check-syntax-json.sh

  quality:
    name: Quality control
    runs-on: [ubuntu-latest]
    needs: [basic-tests]

    steps:
      - name: Setup PHP, with composer and extensions
Tim van Dijen's avatar
Tim van Dijen committed
        id: setup-php
        uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
        with:
Tim van Dijen's avatar
Tim van Dijen committed
          php-version: '8.0'
Tim van Dijen's avatar
Tim van Dijen committed
          tools: composer:v2
          extensions: mbstring, xml

      - name: Setup problem matchers for PHP
        run: echo "::add-matcher::${{ runner.tool_cache }}/php.json"

      - uses: actions/checkout@v3

      - name: Get composer cache directory
        id: composer-cache
        run: echo "::set-output name=dir::$(composer config cache-files-dir)"

      - name: Cache composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        uses: actions/cache@v3
        with:
            path: ${{ steps.composer-cache.outputs.dir }}
            key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
            restore-keys: ${{ runner.os }}-composer-

      - name: Install Composer dependencies
Tim van Dijen's avatar
Tim van Dijen committed
        run: composer install --no-progress --prefer-dist --optimize-autoloader
      - uses: actions/download-artifact@v3
        with:
          name: build-data
          path: ${{ github.workspace }}/build

      - name: Codecov
Tim van Dijen's avatar
Tim van Dijen committed
        uses: codecov/codecov-action@v3

      - name: PHP Code Sniffer
Tim van Dijen's avatar
Tim van Dijen committed
        run: php vendor/bin/phpcs

      - name: Psalm
        continue-on-error: true
Tim van Dijen's avatar
Tim van Dijen committed
        run: php vendor/bin/psalm --show-info=true --shepherd --php-version=${{ steps.setup-php.outputs.php-version }}
Tim van Dijen's avatar
Tim van Dijen committed
        run: php vendor/bin/psalter --issues=UnnecessaryVarAnnotation --dry-run --php-version=${{ steps.setup-php.outputs.php-version }}