Skip to content

Commit

Permalink
Auto-review required dependency matching
Browse files Browse the repository at this point in the history
  • Loading branch information
paulbalandan committed Jan 4, 2022
1 parent 2444763 commit 4541404
Show file tree
Hide file tree
Showing 4 changed files with 94 additions and 3 deletions.
42 changes: 39 additions & 3 deletions .github/workflows/test-phpunit.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ on:
- .github/workflows/test-phpunit.yml

jobs:
tests:
unit-tests:
name: PHP ${{ matrix.php-versions }} - ${{ matrix.db-platforms }}
runs-on: ubuntu-20.04
if: "!contains(github.event.head_commit.message, '[ci skip]')"
Expand Down Expand Up @@ -126,7 +126,7 @@ jobs:
run: echo "TACHYCARDIA_MONITOR_GA=enabled" >> $GITHUB_ENV

- name: Test with PHPUnit
run: script -e -c "vendor/bin/phpunit --color=always"
run: script -e -c "vendor/bin/phpunit --color=always --exclude-group=auto-review"
env:
DB: ${{ matrix.db-platforms }}
TERM: xterm-256color
Expand All @@ -141,9 +141,45 @@ jobs:
COVERALLS_PARALLEL: true
COVERALLS_FLAG_NAME: PHP ${{ matrix.php-versions }} - ${{ matrix.db-platforms }}

auto-review-tests:
name: Automatic Code Review
needs: [unit-tests]
runs-on: ubuntu-20.04

steps:
- name: Checkout
uses: actions/cache@v2

- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: '8.0'
coverage: none

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

- name: Cache dependencies
uses: actions/cache@v2
with:
path: ${{ steps.composercache.outputs.dir }}
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
restore-keys: ${{ runner.os }}-composer-

- name: Install dependencies
run: |
composer update --ansi --no-interaction
composer remove --ansi --dev --unused -W -- rector/rector phpstan/phpstan friendsofphp/php-cs-fixer nexusphp/cs-config codeigniter/coding-standard
env:
COMPOSER_AUTH: ${{ secrets.COMPOSER_AUTH }}

- name: Run AutoReview Tests
run: vendor/bin/phpunit --color=always --group=auto-review

coveralls-finish:
if: github.repository_owner == 'codeigniter4'
needs: [tests]
needs: [unit-tests]
runs-on: ubuntu-20.04

steps:
Expand Down
1 change: 1 addition & 0 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@
"autoload-dev": {
"psr-4": {
"CodeIgniter\\": "tests/system/",
"CodeIgniter\\AutoReview\\": "tests/AutoReview/",
"Utils\\": "utils/"
}
},
Expand Down
3 changes: 3 additions & 0 deletions phpunit.xml.dist
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,9 @@
</coverage>

<testsuites>
<testsuite name="AutoReview">
<directory>./tests/AutoReview</directory>
</testsuite>
<testsuite name="System">
<directory>./tests/system</directory>
<exclude>./tests/system/Database</exclude>
Expand Down
51 changes: 51 additions & 0 deletions tests/AutoReview/ComposerJsonTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
<?php

declare(strict_types=1);

/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <[email protected]>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/

namespace CodeIgniter\AutoReview;

use JsonException;
use PHPUnit\Framework\TestCase;

/**
* @internal
*
* @coversNothing
* @group auto-review
*/
final class ComposerJsonTest extends TestCase
{
public function testFrameworkRequireIsTheSameWithDevRequire(): void
{
$devComposer = $this->getComposerJson(dirname(__DIR__, 2) . '/composer.json');
$frameworkComposer = $this->getComposerJson(dirname(__DIR__, 2) . '/admin/framework/composer.json');

$this->assertSame(
$devComposer['require'],
$frameworkComposer['require'],
'The framework\'s "require" section is not updated with the main composer.json.'
);
}

private function getComposerJson(string $path): array
{
try {
return json_decode((string) file_get_contents($path), true, 512, JSON_THROW_ON_ERROR);
} catch (JsonException $e) {
$this->fail(sprintf(
'The composer.json at "%s" is not readable or does not exist. Error was "%s".',
clean_path($path),
$e->getMessage()
));
}
}
}

0 comments on commit 4541404

Please sign in to comment.