Skip to content

Commit

Permalink
Add support for PHP 8 (nelmio#1064)
Browse files Browse the repository at this point in the history
  • Loading branch information
Yozhef authored Jan 13, 2021
1 parent 792482d commit c019cf4
Show file tree
Hide file tree
Showing 14 changed files with 96 additions and 39 deletions.
10 changes: 10 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ jobs:
php:
- '7.3'
- '7.4'
- '8.0'
symfony-versions: [false]
include:
- description: 'Symfony 3.4'
Expand All @@ -28,6 +29,15 @@ jobs:
- description: 'Symfony 5.2'
php: '7.4'
symfony-versions: 5.2.*
- description: 'Symfony 4.4'
php: '8.0'
symfony-versions: 4.4.*
- description: 'Symfony 5.0'
php: '8.0'
symfony-versions: 5.0.*
- description: 'Symfony 5.2'
php: '8.0'
symfony-versions: 5.2.*

name: PHP ${{ matrix.php }} ${{ matrix.description }}
steps:
Expand Down
2 changes: 0 additions & 2 deletions .github/workflows/static-analysis.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,6 @@ jobs:

- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: '7.4'

- name: Install dependencies
run: composer install --no-progress --no-interaction --prefer-dist
Expand Down
4 changes: 2 additions & 2 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,9 @@
],

"require": {
"php": "^7.3",
"php": "^7.3 || ^8.0",
"fakerphp/faker": "^1.10",
"myclabs/deep-copy": "^1.5.2",
"myclabs/deep-copy": "^1.10",
"sebastian/comparator": "^3.0 || ^4.0",
"symfony/property-access": "^2.8 || ^3.4 || ^4.0 || ^5.0",
"symfony/yaml": "^2.8 || ^3.4 || ^4.0 || ^5.0"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ public function __construct()
{
$this->token = uniqid(__CLASS__);
}

public function canParse(Token $token): bool
{
return $token->getType() === TokenType::RANGE_REFERENCE_TYPE;
Expand All @@ -64,7 +64,7 @@ public function parse(Token $token)
$to = $range->getTo();
$step = $range->getStep();
for ($currentIndex = $from; $currentIndex <= $to; $currentIndex += $step) {
$fixtureId = str_replace($this->token, $currentIndex, $range->getName());
$fixtureId = str_replace($this->token, (string) $currentIndex, $range->getName());
$references[] = new FixtureReferenceValue($fixtureId);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
final class ParameterTokenParser implements ChainableTokenParserInterface
{
use IsAServiceTrait;

public function canParse(Token $token): bool
{
return $token->getType() === TokenType::PARAMETER_TYPE;
Expand All @@ -45,7 +45,7 @@ public function parse(Token $token): ParameterValue
{
$value = $token->getValue();
try {
$paramKey = substr($value, 2, -2);
$paramKey = strlen($value) > 3 ? substr($value, 2, -2) : false;

return new ParameterValue($paramKey);
} catch (TypeError $error) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
final class SimpleReferenceTokenParser implements ChainableTokenParserInterface
{
use IsAServiceTrait;

public function canParse(Token $token): bool
{
return $token->getType() === TokenType::SIMPLE_REFERENCE_TYPE;
Expand All @@ -41,6 +41,10 @@ public function parse(Token $token): FixtureReferenceValue
$value = $token->getValue();

try {
if (!is_string($value) || '' === $value) {
throw ExpressionLanguageExceptionFactory::createForUnparsableToken($token);
}

return new FixtureReferenceValue(substr($value, 1));
} catch (InvalidArgumentException $exception) {
throw ExpressionLanguageExceptionFactory::createForUnparsableToken($token, 0, $exception);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
final class VariableTokenParser implements ChainableTokenParserInterface
{
use IsAServiceTrait;

public function canParse(Token $token): bool
{
return $token->getType() === TokenType::VARIABLE_TYPE;
Expand All @@ -45,7 +45,9 @@ public function canParse(Token $token): bool
*/
public function parse(Token $token)
{
$variable = substr($token->getValue(), 1);
$variable = !is_string($token->getValue()) || $token->getValue() === ''
? false
: substr($token->getValue(), 1);

if ('current' === $variable) {
return new FunctionCallValue(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ public function testThrowsAnErrorIfAMalformedTokenIsGiven(): void
$exception->getMessage()
);
static::assertEquals(0, $exception->getCode());
static::assertNotNull($exception->getPrevious());
static::assertNull($exception->getPrevious());
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,10 @@ public function testThrowsAnErrorIfCouldNotParseToken(): void
$parser = new StringArrayTokenParser(new FakeParser());

$parser->parse($token);
static::fail('Expected exception to be thrown.');

if (PHP_VERSION_ID < 80000) {
static::fail('Expected exception to be thrown.');
}
} catch (ParseException $exception) {
static::assertEquals(
'Could not parse the token "" (type: STRING_ARRAY_TYPE).',
Expand Down
5 changes: 2 additions & 3 deletions tests/FixtureBuilder/ExpressionLanguage/TokenTypeTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ class TokenTypeTest extends TestCase
* @var string[]
*/
private $constants;

protected function setUp(): void
{
$reflClass = new ReflectionClass(TokenType::class);
Expand All @@ -44,10 +44,9 @@ public function testIsImmutable(): void
public function testStaticValues(): void
{
$reflClass = new ReflectionClass(TokenType::class);

$reflProp = $reflClass->getProperty('values');
$reflProp->setAccessible(true);
$values = $reflProp->getValue(TokenType::class);
$values = $reflProp->getValue($reflClass);

static::assertCount(count($this->constants), $values);
foreach ($this->constants as $constant) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ class NoMethodCallInstantiatorTest extends TestCase
* @var NoMethodCallInstantiator
*/
private $instantiator;

protected function setUp(): void
{
$this->instantiator = new NoMethodCallInstantiator();
Expand Down Expand Up @@ -83,10 +83,18 @@ public function testInstantiatesWithReflectionAndNoArguments(): void
(new ReflectionObject($instance))->getProperty('requiredParam');
static::fail('Expected exception to be thrown.');
} catch (ReflectionException $exception) {
static::assertEquals(
'Property requiredParam does not exist',
$exception->getMessage()
);
if (PHP_VERSION_ID < 80000) {
static::assertEquals(
'Property requiredParam does not exist',
$exception->getMessage()
);
} else {
static::assertEquals(
'Property Nelmio\Alice\Entity\Instantiator\DummyWithRequiredParameterInConstructor::$requiredParam'
. ' does not exist',
$exception->getMessage()
);
}
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,12 +77,22 @@ public function testThrowsAnExceptionIfInvalidExpression(): void

static::fail('Expected exception to be thrown.');
} catch (UnresolvableValueException $exception) {
static::assertEquals(
'Could not evaluate the expression ""unclosed string": syntax error, unexpected end of file, expecting variable (T_VARIABLE) or ${ (T_DOLLAR_OPEN_CURLY_BRACES) or {$ (T_CURLY_OPEN)',
$exception->getMessage()
);
static::assertEquals(0, $exception->getCode());
static::assertNotNull($exception->getPrevious());

if (PHP_VERSION_ID < 80000) {
static::assertEquals(
'Could not evaluate the expression ""unclosed string": syntax error, unexpected end of file,'
. ' expecting variable (T_VARIABLE) or ${ (T_DOLLAR_OPEN_CURLY_BRACES) or {$ (T_CURLY_OPEN)',
$exception->getMessage()
);
} else {
static::assertEquals(
'Could not evaluate the expression ""unclosed string": syntax error, unexpected end of file,'
. ' expecting variable or "${" or "{$"',
$exception->getMessage()
);
}
}
}

Expand Down Expand Up @@ -152,10 +162,17 @@ public function testVariablesInference(): void
$resolver->resolve($value, $fixture, $set, $scope, new GenerationContext());
static::fail('Expected an exception to be thrown.');
} catch (UnresolvableValueException $exception) {
static::assertEquals(
'Could not evaluate the expression "$scope": Undefined variable: scope',
$exception->getMessage()
);
if (PHP_VERSION_ID < 80000) {
static::assertEquals(
'Could not evaluate the expression "$scope": Undefined variable: scope',
$exception->getMessage()
);
} else {
static::assertEquals(
'Could not evaluate the expression "$scope": Undefined variable $scope',
$exception->getMessage()
);
}
}
}

Expand Down Expand Up @@ -190,10 +207,17 @@ public function testVariablesInferenceWithCurrent(): void
$resolver->resolve($value, $fixture, $set, $scope, new GenerationContext());
static::fail('Expected an exception to be thrown.');
} catch (UnresolvableValueException $exception) {
static::assertEquals(
'Could not evaluate the expression "$scope": Undefined variable: scope',
$exception->getMessage()
);
if (PHP_VERSION_ID < 80000) {
static::assertEquals(
'Could not evaluate the expression "$scope": Undefined variable: scope',
$exception->getMessage()
);
} else {
static::assertEquals(
'Could not evaluate the expression "$scope": Undefined variable $scope',
$exception->getMessage()
);
}
}
}
}
19 changes: 14 additions & 5 deletions tests/IsAServiceTraitTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -28,13 +28,22 @@ public function testThrowsAnExceptionWhenTryingToCloneInstance(): void
clone new NotClonableDummy();
static::fail('Expected exception to be thrown.');
} catch (Throwable $exception) {
static::assertEquals(
'Call to private Nelmio\Alice\NotClonableDummy::__clone() from context '
.'\'Nelmio\Alice\IsAServiceTraitTest\'',
$exception->getMessage()
);
static::assertEquals(0, $exception->getCode());
static::assertNull($exception->getPrevious());

if (PHP_VERSION_ID < 80000) {
static::assertEquals(
'Call to private Nelmio\Alice\NotClonableDummy::__clone() from context '
. '\'Nelmio\Alice\IsAServiceTraitTest\'',
$exception->getMessage()
);
} else {
static::assertEquals(
'Call to private Nelmio\Alice\NotClonableDummy::__clone() from scope '
. 'Nelmio\Alice\IsAServiceTraitTest',
$exception->getMessage()
);
}
}

$dummyRefl = new ReflectionClass(NotClonableDummy::class);
Expand Down
2 changes: 1 addition & 1 deletion vendor-bin/infection/composer.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"require-dev": {
"infection/infection": "^0.16",
"infection/infection": "^0.20",
"theofidry/composer-inheritance-plugin": "^1.0"
},
"config": {
Expand Down

0 comments on commit c019cf4

Please sign in to comment.