Skip to content

Commit

Permalink
Support PHPUnit 10 (#427)
Browse files Browse the repository at this point in the history
* Including support for PHPUnit 10

* Upping to nunomaduro/collision

* Migrating phpunit config

* Upgrading annotation reader for PHPUnit 10.x

* Adding PSR-4 autoloader dev

* WIP on conversion script

* Work to support the PSR4 migration

* Script to convert to PSR4

* Extend to collision 6 for older versions

* Bump asset manager

* Change to support PHPUnit 10 (#473)
  • Loading branch information
srtfisher authored Nov 21, 2023
1 parent cc5acbe commit 9ba62e1
Show file tree
Hide file tree
Showing 133 changed files with 537 additions and 458 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ vendor
# Cache files
.phpcs/*.json
.phpunit.result.cache
.phpunit.cache/

# Composer files
composer.lock
Expand All @@ -26,4 +27,4 @@ Thumbs.db
# IDE files
*.code-workspace
.idea
.vscode
.vscode
49 changes: 49 additions & 0 deletions bin/convert-psr4-dir.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
<?php
/**
* Helper script to convert the tests/ folder to a PSR-4 folder structure.
*
* Moves tests/example/sub/File.php to tests/Example/Sub/FileTest.php. Only
* convert the sub-part of the path (ignore anything before and including
* tests/).
*
* phpcs:disable
*/

use Mantle\Support\Str;
use Symfony\Component\Finder\Finder;

use function Mantle\Support\Helpers\str;

require_once __DIR__ . '/../vendor/autoload.php';

$finder = ( new Finder() )
->in( realpath( __DIR__ . '/../tests' ) )
->directories()
->notPath( '#fixtures|__snapshots__|template-parts#' );

$base = Str::trailing_slash( realpath( __DIR__ . '/../tests/' ) );

foreach ( $finder as $dir ) {
$old_dir = $dir->getRealPath();

if ( ! is_dir( $old_dir ) ) {
continue;
}

$parts = str( $old_dir )->after( $base )->explode( '/' );

$parts = $parts->map(
fn ( string $part ) => str( $part )->studly()->value(),
);

$new_dir = $base . $parts->implode( '/' );

dump( "Moving {$old_dir} to {$new_dir}" );

shell_exec( "git mv {$old_dir} {$old_dir}-tmp" );
shell_exec( "git mv {$old_dir}-tmp {$new_dir}" );
}

echo "\nDONE!\n";

exit( 0 );
132 changes: 132 additions & 0 deletions bin/convert-psr4-file.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
<?php
/**
* Helper script to convert the tests/ package to PSR-4 coding standards.
*
* The eventual plan is to use this for the rest of the project when that can be
* converted over. Ideally this can be a reusable command in the future.
*
* phpcs:disable
*/

use Symfony\Component\Finder\Finder;

use function Mantle\Support\Helpers\str;

require_once __DIR__ . '/../vendor/autoload.php';

$finder = ( new Finder() )
->in( realpath( __DIR__ . '/../tests' ) )
->name( '*.php' )
->notName( [ 'bootstrap.php', 'sub-example.php', 'base-example.php' ] )
->notPath( '#fixtures|__snapshots__|template-parts#' );

$index = [];
$pass = true;

foreach ( $finder as $file ) {
$filename = str( $file->getFilename() )->lower();

if ( $filename->startsWith( 'test-' ) ) {
$new_filename = $filename
->after( 'test-' )
->before( '.php' )
->studly()
->append( 'Test.php' )
->replace( 'Wordpress', 'WordPress' );

$old_class_name = $filename
->before( '.php' )
->studlyUnderscore()
->replace( 'Wordpress', 'WordPress' );

$new_class_name = $filename
->after( 'test-' )
->before( '.php' )
->studly()
->append( 'Test' )
->replace( 'Wordpress', 'WordPress' );
} else {
foreach ( [ 'trait', 'class' ] as $type ) {
if ( ! $filename->startsWith( "{$type}-" ) ) {
continue;
}

$new_filename = $filename
->after( "{$type}-" )
->before( '.php' )
->studly()
->append( '.php' )
->replace( 'Wordpress', 'WordPress' );

$old_class_name = $filename
->after( "{$type}-" )
->before( '.php' )
->studlyUnderscore();

$new_class_name = $filename
->after( "{$type}-" )
->before( '.php' )
->studly()
->replace( 'Wordpress', 'WordPress' );
}
}

// Check if the file contains the class.
$contents = str( file_get_contents( $file->getRealPath() ) );

$type = $filename->startsWith( 'trait-' ) ? 'trait' : 'class';

if ( ! $contents->contains( "{$type} {$old_class_name->value()} ", true ) ) {
echo $file->getRealPath() . ' does not contain the expected legacy ' . $type . ' ' . $old_class_name->value() . PHP_EOL;

$pass = false;

continue;
}

$index[] = [
$type,
[
$file->getRealPath(),
$old_class_name->value(),
],
[
$file->getPath() . '/' . $new_filename->value(),
$new_class_name->value(),
],
];
}

if ( ! $pass ) {
echo "\n\nPlease fix the above errors before continuing.\n";

exit( 1 );
}

echo 'Processing ' . count( $index ) . ' files...';

foreach ( $index as $item ) {
[ $type, $old, $new ] = $item;

[ $old_file, $old_class ] = $old;
[ $new_file, $new_class ] = $new;

// Update the file with the new class name.
file_put_contents(
$old_file,
str( file_get_contents( $old_file ) )->replace( "{$type} {$old_class} ", "{$type} {$new_class} ", false )->value(),
);

// Update the file name.
if ( ! rename( $old_file, $new_file ) ) {
echo "Failed to rename {$old_file} to {$new_file}.\n";

exit( 1 );
}

echo "Updated {$old_file} to {$new_file} ({$old_class} to {$new_class}).\n";
}

echo "\nDONE!\n";

exit( 0 );
19 changes: 12 additions & 7 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
"require": {
"php": "^8.0",
"alleyinteractive/composer-wordpress-autoloader": "^1.0",
"alleyinteractive/wp-asset-manager": "^1.3.3",
"alleyinteractive/wp-asset-manager": "^1.3.4",
"alleyinteractive/wp-caper": "^2.0.1",
"alleyinteractive/wp-concurrent-remote-requests": "^1.0.2",
"alleyinteractive/wp-filter-side-effects": "^2.0",
Expand All @@ -28,13 +28,13 @@
"monolog/monolog": "^2.9.1",
"nesbot/carbon": "^2.68.1",
"nette/php-generator": "^3.6.9",
"nunomaduro/collision": "^6.4",
"nunomaduro/collision": "^6.0 || ^7.0",
"nunomaduro/termwind": "^1.15.1",
"psr/container": "^1.1.1 || ^2.0.2",
"psr/log": "^1.0.1 || ^2.0 || ^3.0",
"psr/simple-cache": "^3.0",
"ramsey/uuid": "^4.7.4",
"spatie/phpunit-snapshot-assertions": "^4.2",
"spatie/phpunit-snapshot-assertions": "^4.2 || ^5.1",
"symfony/console": "^6.0.19",
"symfony/finder": "^6.0.19",
"symfony/http-foundation": "^6.0.20",
Expand All @@ -55,7 +55,7 @@
"php-stubs/wp-cli-stubs": "^2.8",
"phpstan/phpdoc-parser": "^1.23.1",
"phpstan/phpstan": "1.10.41",
"phpunit/phpunit": "^9.6.10",
"phpunit/phpunit": "^9.3.3 || ^10.0.7",
"predis/predis": "^2.2.0",
"squizlabs/php_codesniffer": "^3.7",
"symplify/monorepo-builder": "^10.3.3",
Expand Down Expand Up @@ -86,6 +86,8 @@
"mantle-framework/testkit": "self.version",
"mantle-framework/view": "self.version"
},
"minimum-stability": "dev",
"prefer-stable": true,
"autoload": {
"files": [
"src/mantle/framework/helpers.php",
Expand All @@ -100,6 +102,11 @@
"src/mantle/testing/autoload.php"
]
},
"autoload-dev": {
"psr-4": {
"Mantle\\Tests\\": "tests/"
}
},
"config": {
"allow-plugins": {
"dealerdirect/phpcodesniffer-composer-installer": true,
Expand Down Expand Up @@ -137,7 +144,5 @@
"@phpstan",
"@phpunit"
]
},
"minimum-stability": "dev",
"prefer-stable": true
}
}
2 changes: 1 addition & 1 deletion monorepo-builder.php
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@
],
ComposerJsonSection::REQUIRE_DEV => [
'alleyinteractive/alley-coding-standards' => '^1.0',
'phpunit/phpunit' => '^9.6.10',
'phpunit/phpunit' => '^9.3.3|^10.0.7',
],
],
);
Expand Down
23 changes: 11 additions & 12 deletions phpunit.xml
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
<?xml version="1.0"?>
<phpunit
bootstrap="tests/bootstrap.php"
backupGlobals="false"
colors="true"
convertErrorsToExceptions="true"
convertNoticesToExceptions="true"
convertWarningsToExceptions="true"
printerClass="NunoMaduro\Collision\Adapters\Phpunit\Printer"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
bootstrap="tests/bootstrap.php"
backupGlobals="false"
colors="true"
xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/10.3/phpunit.xsd"
>
<testsuites>
<testsuite name="mantle-framework">
<directory prefix="test-" suffix=".php">./tests/</directory>
</testsuite>
</testsuites>
<testsuites>
<testsuite name="mantle-framework">
<directory suffix="Test.php">./tests/</directory>
</testsuite>
</testsuites>
</phpunit>
2 changes: 1 addition & 1 deletion src/mantle/assets/composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
"require": {
"php": "^8.0",
"alleyinteractive/composer-wordpress-autoloader": "^1.0",
"alleyinteractive/wp-asset-manager": "^1.3.3",
"alleyinteractive/wp-asset-manager": "^1.3.4",
"mantle-framework/contracts": "^0.12",
"mantle-framework/support": "^0.12"
},
Expand Down
9 changes: 9 additions & 0 deletions src/mantle/support/class-stringable.php
Original file line number Diff line number Diff line change
Expand Up @@ -737,6 +737,15 @@ public function studly() {
return new static( Str::studly( $this->value ) );
}

/**
* Convert a value to studly caps case using underscores.
*
* @return static
*/
public function studlyUnderscore() {
return new static( Str::studly_underscore( $this->value ) );
}

/**
* Returns the portion of the string specified by the start and length parameters.
*
Expand Down
54 changes: 0 additions & 54 deletions src/mantle/testing/class-assert.php

This file was deleted.

Loading

0 comments on commit 9ba62e1

Please sign in to comment.