Fix workflow #3
Annotations
5 errors and 18 warnings
PHP 8.1 lowest dependencies:
src/AntiSpam.php#L42
Method Omines\AntiSpamBundle\AntiSpam::getProfile() should return Omines\AntiSpamBundle\Profile but returns mixed.
|
PHP 8.1 lowest dependencies
Process completed with exit code 1.
|
PHP 8.4 PHP nightly
Child process error (exit code 255): PHP Fatal error: Type of PHPStan\BetterReflection\Reflection\Adapter\ReflectionClass::IS_READONLY must be compatible with ReflectionClass::IS_READONLY of type int in phar:///home/runner/work/antispam-bundle/antispam-bundle/vendor/phpstan/phpstan/phpstan.phar/vendor/ondrejmirtes/better-reflection/src/Reflection/Adapter/ReflectionClass.php on line 34
Fatal error: Type of PHPStan\BetterReflection\Reflection\Adapter\ReflectionClass::IS_READONLY must be compatible with ReflectionClass::IS_READONLY of type int in phar:///home/runner/work/antispam-bundle/antispam-bundle/vendor/phpstan/phpstan/phpstan.phar/vendor/ondrejmirtes/better-reflection/src/Reflection/Adapter/ReflectionClass.php on line 34
|
PHP 8.4 PHP nightly
Process completed with exit code 1.
|
PHP 8.3
Process completed with exit code 1.
|
PHP 8.2:
src/DependencyInjection/AntiSpamExtension.php#L42
Escaped Mutant for Mutator "MethodCallRemoval":
--- Original
+++ New
@@ @@
$container->register($id, Profile::class)->addTag('antispam.profile')->addArgument($name)->addArgument($profile);
}
unset($mergedConfig['profiles']);
- $container->register(AntiSpam::class, AntiSpam::class)->setArgument(1, $mergedConfig)->setAutowired(true);
+
}
public function prepend(ContainerBuilder $container)
{
|
PHP 8.2:
src/DependencyInjection/AntiSpamExtension.php#L45
Escaped Mutant for Mutator "TrueValue":
--- Original
+++ New
@@ @@
$container->register($id, Profile::class)->addTag('antispam.profile')->addArgument($name)->addArgument($profile);
}
unset($mergedConfig['profiles']);
- $container->register(AntiSpam::class, AntiSpam::class)->setArgument(1, $mergedConfig)->setAutowired(true);
+ $container->register(AntiSpam::class, AntiSpam::class)->setArgument(1, $mergedConfig)->setAutowired(false);
}
public function prepend(ContainerBuilder $container)
{
|
PHP 8.2:
src/Form/Extension/FormTypeAntiSpamExtension.php#L76
Escaped Mutant for Mutator "InstanceOf_":
--- Original
+++ New
@@ @@
$config = $child->getConfig();
$type = $config->getType();
while (null !== $type) {
- if ($type->getInnerType() instanceof TextType) {
+ if (true) {
$options = $config->getOptions();
$this->applyTextTypeProfile($options, $profile);
$event->getForm()->add($name, $type->getInnerType()::class, $options);
|
PHP 8.2:
src/Form/Extension/FormTypeAntiSpamExtension.php#L114
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
// Add hidden and signed timer field
if ($timer = $profile->getTimerConfig()) {
if ($form->isRoot()) {
- $form->add(self::uniqueFieldName($form, $timer['field']), SubmitTimerType::class, ['min' => $timer['min'], 'max' => $timer['max']]);
+ $form->add(self::uniqueFieldName($form, $timer['field']), SubmitTimerType::class, ['max' => $timer['max']]);
} else {
$this->logger?->info(sprintf('Ignoring timer configuration from profile "%s" on embedded form', $profile->getName()));
}
|
PHP 8.2:
src/Form/Type/SubmitTimerType.php#L82
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
}
$currentIp = $this->requestStack->getMainRequest()?->getClientIp() ?? self::NO_IP;
if (null !== $currentIp && $ip !== $currentIp) {
- $this->createFormError($form, 'form.timer.mismatch_ip', ['original' => $ip, 'current' => $currentIp], cause: "The client IP address changed from {$ip} to {$currentIp}");
+ $this->createFormError($form, 'form.timer.mismatch_ip', ['current' => $currentIp], cause: "The client IP address changed from {$ip} to {$currentIp}");
}
$age = $this->now()->getTimestamp() - intval($ts);
if ($age < $options['min']) {
|
PHP 8.2:
src/Profile.php#L80
Escaped Mutant for Mutator "Coalesce":
--- Original
+++ New
@@ @@
*/
public function getTextTypeConstraints() : array
{
- return $this->constraints ?? $this->buildTextTypeConstraints();
+ return $this->buildTextTypeConstraints() ?? $this->constraints;
}
/**
* Note that constraints are added in order of increasing cost/effectiveness balance so the resulting array
|
PHP 8.2:
src/Validator/Constraints/BannedMarkup.php#L19
Escaped Mutant for Mutator "TrueValue":
--- Original
+++ New
@@ @@
#[\Attribute(\Attribute::TARGET_PROPERTY | \Attribute::TARGET_METHOD | \Attribute::IS_REPEATABLE)]
class BannedMarkup extends AntiSpamConstraint
{
- public function __construct(public bool $html = true, public bool $bbcode = true, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
+ public function __construct(public bool $html = false, public bool $bbcode = true, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
{
parent::__construct($passive, $stealth, $groups, $payload);
}
}
|
PHP 8.2:
src/Validator/Constraints/BannedMarkup.php#L20
Escaped Mutant for Mutator "TrueValue":
--- Original
+++ New
@@ @@
#[\Attribute(\Attribute::TARGET_PROPERTY | \Attribute::TARGET_METHOD | \Attribute::IS_REPEATABLE)]
class BannedMarkup extends AntiSpamConstraint
{
- public function __construct(public bool $html = true, public bool $bbcode = true, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
+ public function __construct(public bool $html = true, public bool $bbcode = false, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
{
parent::__construct($passive, $stealth, $groups, $payload);
}
}
|
PHP 8.2:
src/Validator/Constraints/BannedPhrases.php#L38
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
#[HasNamedArguments]
public function __construct(string|array $phrases, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
{
- $this->phrases = is_array($phrases) ? $phrases : [$phrases];
+ $this->phrases = is_array($phrases) ? $phrases : [];
parent::__construct($passive, $stealth, $groups, $payload);
}
public function getRegularExpression() : string
|
PHP 8.1 unstable dependencies:
src/DependencyInjection/AntiSpamExtension.php#L42
Escaped Mutant for Mutator "MethodCallRemoval":
--- Original
+++ New
@@ @@
$container->register($id, Profile::class)->addTag('antispam.profile')->addArgument($name)->addArgument($profile);
}
unset($mergedConfig['profiles']);
- $container->register(AntiSpam::class, AntiSpam::class)->setArgument(1, $mergedConfig)->setAutowired(true);
+
}
public function prepend(ContainerBuilder $container)
{
|
PHP 8.1 unstable dependencies:
src/DependencyInjection/AntiSpamExtension.php#L45
Escaped Mutant for Mutator "TrueValue":
--- Original
+++ New
@@ @@
$container->register($id, Profile::class)->addTag('antispam.profile')->addArgument($name)->addArgument($profile);
}
unset($mergedConfig['profiles']);
- $container->register(AntiSpam::class, AntiSpam::class)->setArgument(1, $mergedConfig)->setAutowired(true);
+ $container->register(AntiSpam::class, AntiSpam::class)->setArgument(1, $mergedConfig)->setAutowired(false);
}
public function prepend(ContainerBuilder $container)
{
|
PHP 8.1 unstable dependencies:
src/Form/Extension/FormTypeAntiSpamExtension.php#L76
Escaped Mutant for Mutator "InstanceOf_":
--- Original
+++ New
@@ @@
$config = $child->getConfig();
$type = $config->getType();
while (null !== $type) {
- if ($type->getInnerType() instanceof TextType) {
+ if (true) {
$options = $config->getOptions();
$this->applyTextTypeProfile($options, $profile);
$event->getForm()->add($name, $type->getInnerType()::class, $options);
|
PHP 8.1 unstable dependencies:
src/Form/Extension/FormTypeAntiSpamExtension.php#L114
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
// Add hidden and signed timer field
if ($timer = $profile->getTimerConfig()) {
if ($form->isRoot()) {
- $form->add(self::uniqueFieldName($form, $timer['field']), SubmitTimerType::class, ['min' => $timer['min'], 'max' => $timer['max']]);
+ $form->add(self::uniqueFieldName($form, $timer['field']), SubmitTimerType::class, ['max' => $timer['max']]);
} else {
$this->logger?->info(sprintf('Ignoring timer configuration from profile "%s" on embedded form', $profile->getName()));
}
|
PHP 8.1 unstable dependencies:
src/Form/Type/SubmitTimerType.php#L82
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
}
$currentIp = $this->requestStack->getMainRequest()?->getClientIp() ?? self::NO_IP;
if (null !== $currentIp && $ip !== $currentIp) {
- $this->createFormError($form, 'form.timer.mismatch_ip', ['original' => $ip, 'current' => $currentIp], cause: "The client IP address changed from {$ip} to {$currentIp}");
+ $this->createFormError($form, 'form.timer.mismatch_ip', ['current' => $currentIp], cause: "The client IP address changed from {$ip} to {$currentIp}");
}
$age = $this->now()->getTimestamp() - intval($ts);
if ($age < $options['min']) {
|
PHP 8.1 unstable dependencies:
src/Profile.php#L80
Escaped Mutant for Mutator "Coalesce":
--- Original
+++ New
@@ @@
*/
public function getTextTypeConstraints() : array
{
- return $this->constraints ?? $this->buildTextTypeConstraints();
+ return $this->buildTextTypeConstraints() ?? $this->constraints;
}
/**
* Note that constraints are added in order of increasing cost/effectiveness balance so the resulting array
|
PHP 8.1 unstable dependencies:
src/Validator/Constraints/BannedMarkup.php#L19
Escaped Mutant for Mutator "TrueValue":
--- Original
+++ New
@@ @@
#[\Attribute(\Attribute::TARGET_PROPERTY | \Attribute::TARGET_METHOD | \Attribute::IS_REPEATABLE)]
class BannedMarkup extends AntiSpamConstraint
{
- public function __construct(public bool $html = true, public bool $bbcode = true, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
+ public function __construct(public bool $html = false, public bool $bbcode = true, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
{
parent::__construct($passive, $stealth, $groups, $payload);
}
}
|
PHP 8.1 unstable dependencies:
src/Validator/Constraints/BannedMarkup.php#L20
Escaped Mutant for Mutator "TrueValue":
--- Original
+++ New
@@ @@
#[\Attribute(\Attribute::TARGET_PROPERTY | \Attribute::TARGET_METHOD | \Attribute::IS_REPEATABLE)]
class BannedMarkup extends AntiSpamConstraint
{
- public function __construct(public bool $html = true, public bool $bbcode = true, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
+ public function __construct(public bool $html = true, public bool $bbcode = false, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
{
parent::__construct($passive, $stealth, $groups, $payload);
}
}
|
PHP 8.1 unstable dependencies:
src/Validator/Constraints/BannedPhrases.php#L38
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
#[HasNamedArguments]
public function __construct(string|array $phrases, bool $passive = null, bool $stealth = null, array $groups = null, mixed $payload = null)
{
- $this->phrases = is_array($phrases) ? $phrases : [$phrases];
+ $this->phrases = is_array($phrases) ? $phrases : [];
parent::__construct($passive, $stealth, $groups, $payload);
}
public function getRegularExpression() : string
|