diff --git a/.dependabot/config.yml b/.dependabot/config.yaml similarity index 100% rename from .dependabot/config.yml rename to .dependabot/config.yaml diff --git a/.editorconfig b/.editorconfig index 329611ca..3aaad722 100644 --- a/.editorconfig +++ b/.editorconfig @@ -13,7 +13,7 @@ indent_size = 2 [*.neon] indent_style = tab -[*.yml] +[*.{yaml,yml}] indent_size = 2 [Makefile] diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 285ab618..4c9d7e8d 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -2,7 +2,12 @@ We are using [GitHub Actions](https://github.com/features/actions) as a continuous integration system. -For details, see [`workflows/continuous-integration.yml`](workflows/continuous-integration.yml). +For details, take a look at the following workflow configuration files: + +- [`workflows/integrate.yaml`](workflows/integrate.yaml) +- [`workflows/prune.yaml`](workflows/prune.yaml) +- [`workflows/release.yaml`](workflows/release.yaml) +- [`workflows/renew.yaml`](workflows/renew.yaml) ## Coding Standards @@ -40,7 +45,7 @@ $ make static-code-analysis to run a static code analysis. -We are also using the baseline features of [`phpstan/phpstan`(https://medium.com/@ondrejmirtes/phpstans-baseline-feature-lets-you-hold-new-code-to-a-higher-standard-e77d815a5dff) and [`vimeo/psalm`](https://psalm.dev/docs/running_psalm/dealing_with_code_issues/#using-a-baseline-file). +We are also using the baseline features of [`phpstan/phpstan`](https://medium.com/@ondrejmirtes/phpstans-baseline-feature-lets-you-hold-new-code-to-a-higher-standard-e77d815a5dff) and [`vimeo/psalm`](https://psalm.dev/docs/running_psalm/dealing_with_code_issues/#using-a-baseline-file). Run diff --git a/.github/settings.yml b/.github/settings.yml index 9251615b..26c6eb62 100644 --- a/.github/settings.yml +++ b/.github/settings.yml @@ -35,6 +35,12 @@ branches: - "codecov/project" strict: false restrictions: + + # https://developer.github.com/v3/repos/branches/#parameters-1 + + # Note: User, app, and team restrictions are only available for organization-owned repositories. + # Set to null to disable when using this configuration for a repository on a personal account. + apps: - "dependabot-preview" teams: [] @@ -46,27 +52,27 @@ branches: labels: - name: "bug" - color: "#ee0701" + color: "ee0701" description: "" - name: "dependency" - color: "#0366d6" + color: "0366d6" description: "" - name: "enhancement" - color: "#0e8a16" + color: "0e8a16" description: "" - name: "question" - color: "#cc317c" + color: "cc317c" description: "" - name: "security" - color: "#ee0701" + color: "ee0701" description: "" - name: "stale" - color: "#eeeeee" + color: "eeeeee" description: "" # https://developer.github.com/v3/repos/#edit diff --git a/.github/workflows/continuous-integration.yml b/.github/workflows/integrate.yaml similarity index 73% rename from .github/workflows/continuous-integration.yml rename to .github/workflows/integrate.yaml index d0b1cf73..421582e4 100644 --- a/.github/workflows/continuous-integration.yml +++ b/.github/workflows/integrate.yaml @@ -1,9 +1,9 @@ # https://help.github.com/en/categories/automating-your-workflow-with-github-actions -name: "Continuous Integration" +name: "Integrate" -on: - pull_request: +on: # yamllint disable-line rule:truthy + pull_request: null push: branches: - "master" @@ -29,10 +29,17 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" + + - name: "Lint YAML files" + uses: "ibiqlik/action-yamllint@v1" + with: + config_file: ".yamllint.yaml" + file_or_dir: "." + strict: true - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "none" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" @@ -41,22 +48,26 @@ jobs: - name: "Validate composer.json and composer.lock" run: "composer validate --strict" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('**/composer.lock') }}" restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" @@ -67,7 +78,7 @@ jobs: run: "mkdir -p .build/php-cs-fixer" - name: "Cache cache directory for friendsofphp/php-cs-fixer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: path: ".build/php-cs-fixer" key: "php-${{ matrix.php-version }}-php-cs-fixer-${{ hashFiles('**/composer.lock') }}" @@ -91,36 +102,40 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "none" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" php-version: "${{ matrix.php-version }}" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('**/composer.lock') }}" restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" - name: "Run maglnet/composer-require-checker" - uses: "docker://localheinz/composer-require-checker-action:1.1.1" + uses: "docker://webfactory/composer-require-checker:2.1.0" static-code-analysis: name: "Static Code Analysis" @@ -137,31 +152,35 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "none" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" php-version: "${{ matrix.php-version }}" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "${{ matrix.php-version }}-composer-locked-${{ hashFiles('**/composer.lock') }}" restore-keys: "${{ matrix.php-version }}-composer-locked-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" @@ -197,31 +216,35 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "none" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" php-version: "${{ matrix.php-version }}" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('**/composer.lock') }}" restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" @@ -249,31 +272,35 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "xdebug" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" php-version: "${{ matrix.php-version }}" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('**/composer.lock') }}" restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" @@ -303,31 +330,35 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "xdebug" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" php-version: "${{ matrix.php-version }}" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('**/composer.lock') }}" restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" diff --git a/.github/workflows/stale.yml b/.github/workflows/prune.yaml similarity index 76% rename from .github/workflows/stale.yml rename to .github/workflows/prune.yaml index 7af8aa2a..449e4652 100644 --- a/.github/workflows/stale.yml +++ b/.github/workflows/prune.yaml @@ -1,29 +1,31 @@ # https://github.com/actions/stale -name: "Stale" +name: "Prune" -on: +on: # yamllint disable-line rule:truthy schedule: - cron: "0 12 * * *" jobs: - stale: + prune: + name: "Issues" + runs-on: "ubuntu-latest" steps: - - name: "Close stale issues and pull requests" - uses: "actions/stale@v1.1.0" + - name: "Prune issues and pull requests" + uses: "actions/stale@v1" with: days-before-close: 5 days-before-stale: 60 repo-token: "${{ secrets.ERGEBNIS_BOT_TOKEN }}" stale-issue-label: "stale" - stale-issue-message: > + stale-issue-message: | Since this issue has not had any activity within the last sixty days, I have marked it as stale. I will close it if no further activity occurs within the next five days. stale-pr-label: "stale" - stale-pr-message: > + stale-pr-message: | Since this pull request has not had any activity within the last sixty days, I have marked it as stale. I will close it if no further activity occurs within the next five days. diff --git a/.github/workflows/continuous-deployment.yml b/.github/workflows/release.yaml similarity index 86% rename from .github/workflows/continuous-deployment.yml rename to .github/workflows/release.yaml index c8b2a2e9..5cd6d94b 100644 --- a/.github/workflows/continuous-deployment.yml +++ b/.github/workflows/release.yaml @@ -1,8 +1,8 @@ # https://help.github.com/en/categories/automating-your-workflow-with-github-actions -name: "Continuous Deployment" +name: "Release" -on: +on: # yamllint disable-line rule:truthy push: tags: - "**" @@ -19,7 +19,7 @@ jobs: run: "echo \"::set-output name=tag::${GITHUB_REF#refs/tags/}\"" - name: "Create release" - uses: "actions/create-release@v1.0.0" + uses: "actions/create-release@v1" env: GITHUB_TOKEN: "${{ secrets.ERGEBNIS_BOT_TOKEN }}" with: diff --git a/.github/workflows/license.yml b/.github/workflows/renew.yaml similarity index 78% rename from .github/workflows/license.yml rename to .github/workflows/renew.yaml index ed8a103d..03a730b2 100644 --- a/.github/workflows/license.yml +++ b/.github/workflows/renew.yaml @@ -1,8 +1,8 @@ # https://help.github.com/en/categories/automating-your-workflow-with-github-actions -name: "License" +name: "Renew" -on: +on: # yamllint disable-line rule:truthy schedule: - cron: "1 0 1 1 *" @@ -25,10 +25,10 @@ jobs: steps: - name: "Checkout" - uses: "actions/checkout@v2.0.0" + uses: "actions/checkout@v2" - name: "Install PHP with extensions" - uses: "shivammathur/setup-php@1.8.1" + uses: "shivammathur/setup-php@v2" with: coverage: "none" extensions: "${{ env.REQUIRED_PHP_EXTENSIONS }}" @@ -37,22 +37,26 @@ jobs: - name: "Validate composer.json and composer.lock" run: "composer validate --strict" + - name: "Determine composer cache directory" + id: "determine-composer-cache-directory" + run: "echo \"::set-output name=directory::$(composer config cache-dir)\"" + - name: "Cache dependencies installed with composer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: - path: "~/.composer/cache" + path: "${{ steps.determine-composer-cache-directory.outputs.directory }}" key: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-${{ hashFiles('**/composer.lock') }}" restore-keys: "php-${{ matrix.php-version }}-composer-${{ matrix.dependencies }}-" - - name: "Install lowest dependencies with composer" + - name: "Install lowest dependencies from composer.json" if: "matrix.dependencies == 'lowest'" run: "composer update --no-interaction --no-progress --no-suggest --prefer-lowest" - - name: "Install locked dependencies with composer" + - name: "Install locked dependencies from composer.lock" if: "matrix.dependencies == 'locked'" run: "composer install --no-interaction --no-progress --no-suggest" - - name: "Install highest dependencies with composer" + - name: "Install highest dependencies from composer.json" if: "matrix.dependencies == 'highest'" run: "composer update --no-interaction --no-progress --no-suggest" @@ -60,7 +64,7 @@ jobs: run: "mkdir -p .build/php-cs-fixer" - name: "Cache cache directory for friendsofphp/php-cs-fixer" - uses: "actions/cache@v1.0.3" + uses: "actions/cache@v1" with: path: ".build/php-cs-fixer" key: "php-${{ matrix.php-version }}-php-cs-fixer-${{ hashFiles('**/composer.lock') }}" diff --git a/.php_cs b/.php_cs index 8545b6af..b996ac22 100644 --- a/.php_cs +++ b/.php_cs @@ -32,13 +32,15 @@ $config->getFinder() ->ignoreDotFiles(false) ->in(__DIR__) ->exclude([ - '.build', - '.dependabot', - '.github', - 'test/Fixture', + '.build/', + '.dependabot/', + '.github/', + 'test/Fixture/', ]) - ->name('.php_cs') - ->name('.php_cs.fixture'); + ->name([ + '.php_cs', + '.php_cs.fixture', + ]); $config->setCacheFile(__DIR__ . '/.build/php-cs-fixer/.php_cs.cache'); diff --git a/.yamllint.yaml b/.yamllint.yaml new file mode 100644 index 00000000..17b1b556 --- /dev/null +++ b/.yamllint.yaml @@ -0,0 +1,65 @@ +extends: "default" + +ignore: | + .build/ + vendor/ + +rules: + braces: + max-spaces-inside-empty: 0 + max-spaces-inside: 1 + min-spaces-inside-empty: 0 + min-spaces-inside: 1 + brackets: + max-spaces-inside-empty: 0 + max-spaces-inside: 0 + min-spaces-inside-empty: 0 + min-spaces-inside: 0 + colons: + max-spaces-after: 1 + max-spaces-before: 0 + commas: + max-spaces-after: 1 + max-spaces-before: 0 + min-spaces-after: 1 + comments: + ignore-shebangs: true + min-spaces-from-content: 1 + require-starting-space: true + comments-indentation: "enable" + document-end: + present: false + document-start: + present: false + indentation: + check-multi-line-strings: true + indent-sequences: true + spaces: 2 + empty-lines: + max-end: 0 + max-start: 0 + max: 1 + empty-values: + forbid-in-block-mappings: true + forbid-in-flow-mappings: true + hyphens: + max-spaces-after: 2 + key-duplicates: "enable" + key-ordering: "disable" + line-length: "disable" + new-line-at-end-of-file: "enable" + new-lines: + type: "unix" + octal-values: + forbid-implicit-octal: true + quoted-strings: + quote-type: "double" + trailing-spaces: "enable" + truthy: + allowed-values: + - "false" + - "true" + +yaml-files: + - '*.yaml' + - '*.yml' diff --git a/Makefile b/Makefile index b3190220..2d418260 100644 --- a/Makefile +++ b/Makefile @@ -6,17 +6,19 @@ it: coding-standards dependency-analysis static-code-analysis tests ## Runs the .PHONY: code-coverage code-coverage: vendor ## Collects coverage from running unit tests with phpunit/phpunit + mkdir -p .build/phpunit vendor/bin/phpunit --configuration=test/Integration/phpunit.xml --dump-xdebug-filter=.build/phpunit/xdebug-filter.php vendor/bin/phpunit --configuration=test/Integration/phpunit.xml --coverage-text --prepend=.build/phpunit/xdebug-filter.php .PHONY: coding-standards coding-standards: vendor ## Fixes code style issues with friendsofphp/php-cs-fixer + yamllint -c .yamllint.yaml --strict . mkdir -p .build/php-cs-fixer vendor/bin/php-cs-fixer fix --config=.php_cs --diff --diff-format=udiff --verbose .PHONY: dependency-analysis dependency-analysis: vendor ## Runs a dependency analysis with maglnet/composer-require-checker - docker run --interactive --rm --tty --workdir=/app --volume ${PWD}:/app localheinz/composer-require-checker-action:1.1.1 + docker run --interactive --rm --tty --volume ${PWD}:/app webfactory/composer-require-checker:2.1.0 .PHONY: help help: ## Displays this list of targets with descriptions diff --git a/README.md b/README.md index 2d41b2bd..c04bbb5f 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,9 @@ # phpstan-rules -[![Continuous Deployment](https://github.com/ergebnis/phpstan-rules/workflows/Continuous%20Deployment/badge.svg)](https://github.com/ergebnis/phpstan-rules/actions) -[![Continuous Integration](https://github.com/ergebnis/phpstan-rules/workflows/Continuous%20Integration/badge.svg)](https://github.com/ergebnis/phpstan-rules/actions) +[![Integrate](https://github.com/ergebnis/phpstan-rules/workflows/Integrate/badge.svg?branch=master)](https://github.com/ergebnis/phpstan-rules/actions) +[![Prune](https://github.com/ergebnis/phpstan-rules/workflows/Prune/badge.svg?branch=master)](https://github.com/ergebnis/phpstan-rules/actions) +[![Release](https://github.com/ergebnis/phpstan-rules/workflows/Release/badge.svg?branch=master)](https://github.com/ergebnis/phpstan-rules/actions) +[![Renew](https://github.com/ergebnis/phpstan-rules/workflows/Renew/badge.svg?branch=master)](https://github.com/ergebnis/phpstan-rules/actions) [![Code Coverage](https://codecov.io/gh/ergebnis/phpstan-rules/branch/master/graph/badge.svg)](https://codecov.io/gh/ergebnis/phpstan-rules) [![Type Coverage](https://shepherd.dev/github/ergebnis/phpstan-rules/coverage.svg)](https://shepherd.dev/github/ergebnis/phpstan-rules) diff --git a/phpstan.neon b/phpstan.neon index 00a39dc8..57a10422 100644 --- a/phpstan.neon +++ b/phpstan.neon @@ -13,6 +13,6 @@ parameters: inferPrivatePropertyTypeFromConstructor: true level: max paths: - - src - - test - tmpDir: %currentWorkingDirectory%/.build/phpstan + - src/ + - test/ + tmpDir: %currentWorkingDirectory%/.build/phpstan/ diff --git a/psalm-baseline.xml b/psalm-baseline.xml index cc885ec2..06e5f373 100644 --- a/psalm-baseline.xml +++ b/psalm-baseline.xml @@ -1,14 +1,48 @@ - + + + + $node->namespacedName + $docComment->getReformattedText() + $annotation + + + $annotation + + + toString + + + + + $node->namespacedName + + + + $node->namespacedName + + + + $functionName + + + $functionName + $node->namespacedName + + $functionName + + + $functionName + $node->namespacedName @@ -18,10 +52,19 @@ $interfaceImplementedByContainer $interfaceImplementedByContainer + + array + $className + + + iterable + iterable + + diff --git a/psalm.xml b/psalm.xml index 1510c617..33b5c2a6 100644 --- a/psalm.xml +++ b/psalm.xml @@ -5,6 +5,7 @@ xsi:schemaLocation="https://getpsalm.org/schema/config vendor/vimeo/psalm/config.xsd" cacheDirectory=".build/psalm" errorBaseline="psalm-baseline.xml" + errorLevel="1" resolveFromConfigFile="true" > @@ -16,11 +17,11 @@ - - + + - - + + diff --git a/test/Integration/phpunit.xml b/test/Integration/phpunit.xml index 4047d404..91d7970f 100644 --- a/test/Integration/phpunit.xml +++ b/test/Integration/phpunit.xml @@ -29,7 +29,7 @@ - ../../src + ../../src/ diff --git a/test/Unit/phpunit.xml b/test/Unit/phpunit.xml index 07b9c636..5d606146 100644 --- a/test/Unit/phpunit.xml +++ b/test/Unit/phpunit.xml @@ -29,7 +29,7 @@ - ../../src + ../../src/