From 52d1b7161a015f1ce14354ed8163a90c6a97b3c7 Mon Sep 17 00:00:00 2001 From: Al3x Zamponi <562324+alexz707@users.noreply.github.com> Date: Tue, 21 Jan 2025 14:11:49 +0100 Subject: [PATCH] update php and pimcore, fix deprecations (#90) --- .../ci/scripts/setup-pimcore-environment.sh | 4 - .github/workflows/static-analysis.yml | 116 ++++++++++++------ composer.json | 8 +- 3 files changed, 83 insertions(+), 45 deletions(-) diff --git a/.github/ci/scripts/setup-pimcore-environment.sh b/.github/ci/scripts/setup-pimcore-environment.sh index aae7321..f4093e1 100755 --- a/.github/ci/scripts/setup-pimcore-environment.sh +++ b/.github/ci/scripts/setup-pimcore-environment.sh @@ -3,7 +3,3 @@ set -eu -o xtrace cp .github/ci/files/.env . - -if [ ${REQUIRE_ADMIN_BUNDLE} = true ]; then - composer require -n --no-update pimcore/admin-ui-classic-bundle -fi \ No newline at end of file diff --git a/.github/workflows/static-analysis.yml b/.github/workflows/static-analysis.yml index 405bc4c..cc70aac 100644 --- a/.github/workflows/static-analysis.yml +++ b/.github/workflows/static-analysis.yml @@ -1,53 +1,95 @@ -name: "Static Analysis" +name: "Static analysis centralised" on: - pull_request: - branches: - - "[0-9]+.[0-9]+" - - "[0-9]+.x" + schedule: + - cron: '0 3 * * 1,3,5' + workflow_dispatch: push: branches: - "[0-9]+.[0-9]+" - "[0-9]+.x" + - "feature-*" + pull_request: + types: [ opened, synchronize, reopened ] + + +env: + PIMCORE_PROJECT_ROOT: ${{ github.workspace }} + PRIVATE_REPO: ${{ github.event.repository.private }} jobs: - static-analysis-phpstan: - name: "Static Analysis with PHPStan" - runs-on: "ubuntu-20.04" - strategy: - matrix: - include: - - { php-version: "8.1", dependencies: "lowest", require_admin_bundle: false } - - { php-version: "8.2", dependencies: "highest", require_admin_bundle: true } - - { php-version: "8.3", dependencies: "highest", pimcore_version: "11.x-dev", require_admin_bundle: true } + setup-matrix: + runs-on: ubuntu-latest + outputs: + php_versions: ${{ steps.parse-php-versions.outputs.php_versions }} + matrix: ${{ steps.set-matrix.outputs.matrix }} + private_repo: ${{ env.PRIVATE_REPO }} steps: - - name: "Checkout code" - uses: "actions/checkout@v2" + - name: Checkout code + uses: actions/checkout@v4 - - name: "Install PHP" - uses: "shivammathur/setup-php@v2" + - name: Checkout reusable workflow repo + uses: actions/checkout@v4 with: - coverage: "none" - php-version: "${{ matrix.php-version }}" - - - name: "Setup Pimcore environment" - env: - REQUIRE_ADMIN_BUNDLE: "${{ matrix.require_admin_bundle }}" - run: | - .github/ci/scripts/setup-pimcore-environment.sh + repository: pimcore/workflows-collection-public + ref: main + path: reusable-workflows - - name: "Update Pimcore version" - env: - PIMCORE_VERSION: "${{ matrix.pimcore_version }}" + - name: Parse PHP versions from composer.json + id: parse-php-versions run: | - if [ ! -z "$PIMCORE_VERSION" ]; then - composer require --no-update pimcore/pimcore:"${PIMCORE_VERSION}" + if [ -f composer.json ]; then + php_versions=$(jq -r '.require.php' composer.json | grep -oP '\d+\.\d+' | tr '\n' ',' | sed 's/,$//') + if [ -z "$php_versions" ]; then + echo "No PHP versions found in composer.json" + echo "Setting default PHP value" + echo "php_versions=default" >> $GITHUB_OUTPUT + else + echo "php_versions=$php_versions" >> $GITHUB_OUTPUT + echo "#### php versions #### : $php_versions" + fi + else + echo "composer.json not found" + exit 1 fi - - name: "Install dependencies with Composer" - uses: "ramsey/composer-install@v2" - with: - dependency-versions: "${{ matrix.dependencies }}" + - name: Set up matrix + id: set-matrix + run: | + php_versions="${{ steps.parse-php-versions.outputs.php_versions }}" + + MATRIX_JSON=$(cat reusable-workflows/phpstan-configuration/matrix-config.json) + + IFS=',' read -ra VERSIONS_ARRAY <<< "$php_versions" + + FILTERED_MATRIX_JSON=$(echo $MATRIX_JSON | jq --arg php_versions "$php_versions" ' + { + matrix: [ + .configs[] | + select(.php_version == $php_versions) | + .matrix[] + ] + }') + + ENCODED_MATRIX_JSON=$(echo $FILTERED_MATRIX_JSON | jq -c .) + + echo "matrix=${ENCODED_MATRIX_JSON}" >> $GITHUB_OUTPUT - - name: "Run a static analysis with phpstan/phpstan" - run: "vendor/bin/phpstan analyse --memory-limit=-1" + static-analysis: + needs: setup-matrix + strategy: + matrix: ${{ fromJson(needs.setup-matrix.outputs.matrix) }} + uses: pimcore/workflows-collection-public/.github/workflows/reusable-static-analysis-centralized.yaml@main + with: + APP_ENV: test + PIMCORE_TEST: 1 + PRIVATE_REPO: ${{ needs.setup-matrix.outputs.private_repo}} + PHP_VERSION: ${{ matrix.matrix.php-version }} + SYMFONY: ${{ matrix.matrix.symfony }} + DEPENDENCIES: ${{ matrix.matrix.dependencies }} + EXPERIMENTAL: ${{ matrix.matrix.experimental }} + PIMCORE_VERSION: ${{ matrix.matrix.pimcore_version }} + COMPOSER_OPTIONS: ${{ matrix.matrix.composer_options }} + secrets: + SSH_PRIVATE_KEY_PIMCORE_DEPLOYMENTS_USER: ${{ secrets.SSH_PRIVATE_KEY_PIMCORE_DEPLOYMENTS_USER }} + COMPOSER_PIMCORE_REPO_PACKAGIST_TOKEN: ${{ secrets.COMPOSER_PIMCORE_REPO_PACKAGIST_TOKEN }} \ No newline at end of file diff --git a/composer.json b/composer.json index 90dfd09..fdc636b 100644 --- a/composer.json +++ b/composer.json @@ -8,14 +8,14 @@ "prefer-stable": true, "minimum-stability": "dev", "require": { - "php": "~8.1.0 || ~8.2.0 || ~8.3.0", - "pimcore/admin-ui-classic-bundle": "^1.0", - "pimcore/pimcore": "^11.2", + "php": "~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0", + "pimcore/admin-ui-classic-bundle": "^1.0 || ^2.0", + "pimcore/pimcore": "^11.2 || ^12.0", "pimcore/output-data-config-toolkit-bundle": "^4.1 || ^5.0", "symfony/http-foundation": "^6.3" }, "require-dev": { - "phpstan/phpstan": "^1.9" + "phpstan/phpstan": "^1.12.15" }, "autoload": { "psr-4": {