Expose contracts #185
test.yml
on: pull_request
Matrix: deptrac
Matrix: infection
Matrix: unit-tests
Annotations
42 warnings
deptrac (ubuntu-24.04, 8.3)
Your workflow is using a version of actions/cache that is scheduled for deprecation, actions/cache@v2. Please update your workflow to use either v3 or v4 of actions/cache to avoid interruptions. Learn more: https://github.blog/changelog/2024-12-05-notice-of-upcoming-releases-and-breaking-changes-for-github-actions/#actions-cache-v1-v2-and-actions-toolkit-cache-package-closing-down
|
deptrac (ubuntu-24.04, 8.2)
Your workflow is using a version of actions/cache that is scheduled for deprecation, actions/cache@v2. Please update your workflow to use either v3 or v4 of actions/cache to avoid interruptions. Learn more: https://github.blog/changelog/2024-12-05-notice-of-upcoming-releases-and-breaking-changes-for-github-actions/#actions-cache-v1-v2-and-actions-toolkit-cache-package-closing-down
|
infection (ubuntu-24.04, 8.1)
Your workflow is using a version of actions/cache that is scheduled for deprecation, actions/cache@v2. Please update your workflow to use either v3 or v4 of actions/cache to avoid interruptions. Learn more: https://github.blog/changelog/2024-12-05-notice-of-upcoming-releases-and-breaking-changes-for-github-actions/#actions-cache-v1-v2-and-actions-toolkit-cache-package-closing-down
|
infection (ubuntu-24.04, 8.2)
Your workflow is using a version of actions/cache that is scheduled for deprecation, actions/cache@v2. Please update your workflow to use either v3 or v4 of actions/cache to avoid interruptions. Learn more: https://github.blog/changelog/2024-12-05-notice-of-upcoming-releases-and-breaking-changes-for-github-actions/#actions-cache-v1-v2-and-actions-toolkit-cache-package-closing-down
|
infection (ubuntu-24.04, 8.3)
Your workflow is using a version of actions/cache that is scheduled for deprecation, actions/cache@v2. Please update your workflow to use either v3 or v4 of actions/cache to avoid interruptions. Learn more: https://github.blog/changelog/2024-12-05-notice-of-upcoming-releases-and-breaking-changes-for-github-actions/#actions-cache-v1-v2-and-actions-toolkit-cache-package-closing-down
|
deptrac (ubuntu-24.04, 8.1)
Your workflow is using a version of actions/cache that is scheduled for deprecation, actions/cache@v2. Please update your workflow to use either v3 or v4 of actions/cache to avoid interruptions. Learn more: https://github.blog/changelog/2024-12-05-notice-of-upcoming-releases-and-breaking-changes-for-github-actions/#actions-cache-v1-v2-and-actions-toolkit-cache-package-closing-down
|
infection (ubuntu-24.04, 8.1):
src/Contract/Analyser/EventHelper.php#L41
Escaped Mutant for Mutator "LogicalAnd":
--- Original
+++ New
@@ @@
public function shouldViolationBeSkipped(string $depender, string $dependent) : bool
{
$skippedViolation = $this->skippedViolations[$depender] ?? [];
- $matched = [] !== $skippedViolation && in_array($dependent, $skippedViolation, true);
+ $matched = [] !== $skippedViolation || in_array($dependent, $skippedViolation, true);
if (!$matched) {
return false;
}
|
infection (ubuntu-24.04, 8.1):
src/Contract/Ast/AstMap/FileReference.php#L35
Escaped Mutant for Mutator "UnwrapArrayMap":
--- Original
+++ New
@@ @@
/** @psalm-suppress ImpureFunctionCall */
$this->classLikeReferences = array_map(fn(ClassLikeReference $classReference): ClassLikeReference => $classReference->withFileReference($this), $classLikeReferences);
/** @psalm-suppress ImpureFunctionCall */
- $this->functionReferences = array_map(fn(FunctionReference $functionReference): FunctionReference => $functionReference->withFileReference($this), $functionReferences);
+ $this->functionReferences = $functionReferences;
}
public function getFilepath() : string
{
|
infection (ubuntu-24.04, 8.1):
src/Contract/Config/CollectorConfig.php#L20
Escaped Mutant for Mutator "PublicVisibility":
--- Original
+++ New
@@ @@
return $this;
}
/** @return array{'type': string, 'private': bool, ...} */
- public function toArray() : array
+ protected function toArray() : array
{
return ['type' => $this->collectorType->value, 'private' => $this->private];
}
}
|
infection (ubuntu-24.04, 8.1):
src/Contract/Config/DeptracConfig.php#L134
Escaped Mutant for Mutator "NotIdentical":
--- Original
+++ New
@@ @@
if ([] !== $this->formatters) {
$config['formatters'] = array_map(static fn(FormatterConfigInterface $formatterConfig) => $formatterConfig->toArray(), $this->formatters);
}
- if ([] !== $this->excludeFiles) {
+ if ([] === $this->excludeFiles) {
$config['exclude_files'] = $this->excludeFiles;
}
if ([] !== $this->layers) {
|
infection (ubuntu-24.04, 8.1):
src/Contract/Config/DeptracConfig.php#L146
Escaped Mutant for Mutator "NotIdentical":
--- Original
+++ New
@@ @@
if ([] !== $this->rulesets) {
$config['ruleset'] = array_map(static fn(Ruleset $rulesetConfig) => $rulesetConfig->toArray(), $this->rulesets);
}
- if ([] !== $this->skipViolations) {
+ if ([] === $this->skipViolations) {
$config['skip_violations'] = $this->skipViolations;
}
$config['ignore_uncovered_internal_classes'] = $this->ignoreUncoveredInternalClasses;
|
infection (ubuntu-24.04, 8.1):
src/Contract/Config/DeptracConfig.php#L153
Escaped Mutant for Mutator "ArrayOneItem":
--- Original
+++ New
@@ @@
}
$config['ignore_uncovered_internal_classes'] = $this->ignoreUncoveredInternalClasses;
$config['cache_file'] = $this->cacheFile;
- return $config;
+ return count($config) > 1 ? array_slice($config, 0, 1, true) : $config;
}
public function getExtensionAlias() : string
{
|
infection (ubuntu-24.04, 8.1):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L24
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.1):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L25
Escaped Mutant for Mutator "DecrementInteger":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [ProcessEvent::class => ['invoke', -2]];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.1):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L25
Escaped Mutant for Mutator "IncrementInteger":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [ProcessEvent::class => ['invoke', -0]];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.1):
src/Core/Analyser/EventHandler/DependsOnInternalToken.php#L50
Escaped Mutant for Mutator "MethodCallRemoval":
--- Original
+++ New
@@ @@
$isInternal = $event->dependentReference->hasTag($this->internalTag);
}
if ($isInternal) {
- $this->eventHelper->addSkippableViolation($event, $ruleset, $dependentLayer, $this);
+
$event->stopPropagation();
}
}
|
infection (ubuntu-24.04, 8.1)
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
infection (ubuntu-24.04, 8.2):
src/Contract/Analyser/EventHelper.php#L41
Escaped Mutant for Mutator "LogicalAnd":
--- Original
+++ New
@@ @@
public function shouldViolationBeSkipped(string $depender, string $dependent) : bool
{
$skippedViolation = $this->skippedViolations[$depender] ?? [];
- $matched = [] !== $skippedViolation && in_array($dependent, $skippedViolation, true);
+ $matched = [] !== $skippedViolation || in_array($dependent, $skippedViolation, true);
if (!$matched) {
return false;
}
|
infection (ubuntu-24.04, 8.2):
src/Contract/Ast/AstMap/FileReference.php#L35
Escaped Mutant for Mutator "UnwrapArrayMap":
--- Original
+++ New
@@ @@
/** @psalm-suppress ImpureFunctionCall */
$this->classLikeReferences = array_map(fn(ClassLikeReference $classReference): ClassLikeReference => $classReference->withFileReference($this), $classLikeReferences);
/** @psalm-suppress ImpureFunctionCall */
- $this->functionReferences = array_map(fn(FunctionReference $functionReference): FunctionReference => $functionReference->withFileReference($this), $functionReferences);
+ $this->functionReferences = $functionReferences;
}
public function getFilepath() : string
{
|
infection (ubuntu-24.04, 8.2):
src/Contract/Config/CollectorConfig.php#L20
Escaped Mutant for Mutator "PublicVisibility":
--- Original
+++ New
@@ @@
return $this;
}
/** @return array{'type': string, 'private': bool, ...} */
- public function toArray() : array
+ protected function toArray() : array
{
return ['type' => $this->collectorType->value, 'private' => $this->private];
}
}
|
infection (ubuntu-24.04, 8.2):
src/Contract/Config/DeptracConfig.php#L134
Escaped Mutant for Mutator "NotIdentical":
--- Original
+++ New
@@ @@
if ([] !== $this->formatters) {
$config['formatters'] = array_map(static fn(FormatterConfigInterface $formatterConfig) => $formatterConfig->toArray(), $this->formatters);
}
- if ([] !== $this->excludeFiles) {
+ if ([] === $this->excludeFiles) {
$config['exclude_files'] = $this->excludeFiles;
}
if ([] !== $this->layers) {
|
infection (ubuntu-24.04, 8.2):
src/Contract/Config/DeptracConfig.php#L146
Escaped Mutant for Mutator "NotIdentical":
--- Original
+++ New
@@ @@
if ([] !== $this->rulesets) {
$config['ruleset'] = array_map(static fn(Ruleset $rulesetConfig) => $rulesetConfig->toArray(), $this->rulesets);
}
- if ([] !== $this->skipViolations) {
+ if ([] === $this->skipViolations) {
$config['skip_violations'] = $this->skipViolations;
}
$config['ignore_uncovered_internal_classes'] = $this->ignoreUncoveredInternalClasses;
|
infection (ubuntu-24.04, 8.2):
src/Contract/Config/DeptracConfig.php#L153
Escaped Mutant for Mutator "ArrayOneItem":
--- Original
+++ New
@@ @@
}
$config['ignore_uncovered_internal_classes'] = $this->ignoreUncoveredInternalClasses;
$config['cache_file'] = $this->cacheFile;
- return $config;
+ return count($config) > 1 ? array_slice($config, 0, 1, true) : $config;
}
public function getExtensionAlias() : string
{
|
infection (ubuntu-24.04, 8.2):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L24
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.2):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L25
Escaped Mutant for Mutator "DecrementInteger":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [ProcessEvent::class => ['invoke', -2]];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.2):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L25
Escaped Mutant for Mutator "IncrementInteger":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [ProcessEvent::class => ['invoke', -0]];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.2):
src/Core/Analyser/EventHandler/DependsOnInternalToken.php#L50
Escaped Mutant for Mutator "MethodCallRemoval":
--- Original
+++ New
@@ @@
$isInternal = $event->dependentReference->hasTag($this->internalTag);
}
if ($isInternal) {
- $this->eventHelper->addSkippableViolation($event, $ruleset, $dependentLayer, $this);
+
$event->stopPropagation();
}
}
|
infection (ubuntu-24.04, 8.2)
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
infection (ubuntu-24.04, 8.3):
src/Contract/Analyser/EventHelper.php#L41
Escaped Mutant for Mutator "LogicalAnd":
--- Original
+++ New
@@ @@
public function shouldViolationBeSkipped(string $depender, string $dependent) : bool
{
$skippedViolation = $this->skippedViolations[$depender] ?? [];
- $matched = [] !== $skippedViolation && in_array($dependent, $skippedViolation, true);
+ $matched = [] !== $skippedViolation || in_array($dependent, $skippedViolation, true);
if (!$matched) {
return false;
}
|
infection (ubuntu-24.04, 8.3):
src/Contract/Ast/AstMap/FileReference.php#L35
Escaped Mutant for Mutator "UnwrapArrayMap":
--- Original
+++ New
@@ @@
/** @psalm-suppress ImpureFunctionCall */
$this->classLikeReferences = array_map(fn(ClassLikeReference $classReference): ClassLikeReference => $classReference->withFileReference($this), $classLikeReferences);
/** @psalm-suppress ImpureFunctionCall */
- $this->functionReferences = array_map(fn(FunctionReference $functionReference): FunctionReference => $functionReference->withFileReference($this), $functionReferences);
+ $this->functionReferences = $functionReferences;
}
public function getFilepath() : string
{
|
infection (ubuntu-24.04, 8.3):
src/Contract/Config/CollectorConfig.php#L20
Escaped Mutant for Mutator "PublicVisibility":
--- Original
+++ New
@@ @@
return $this;
}
/** @return array{'type': string, 'private': bool, ...} */
- public function toArray() : array
+ protected function toArray() : array
{
return ['type' => $this->collectorType->value, 'private' => $this->private];
}
}
|
infection (ubuntu-24.04, 8.3):
src/Contract/Config/DeptracConfig.php#L134
Escaped Mutant for Mutator "NotIdentical":
--- Original
+++ New
@@ @@
if ([] !== $this->formatters) {
$config['formatters'] = array_map(static fn(FormatterConfigInterface $formatterConfig) => $formatterConfig->toArray(), $this->formatters);
}
- if ([] !== $this->excludeFiles) {
+ if ([] === $this->excludeFiles) {
$config['exclude_files'] = $this->excludeFiles;
}
if ([] !== $this->layers) {
|
infection (ubuntu-24.04, 8.3):
src/Contract/Config/DeptracConfig.php#L146
Escaped Mutant for Mutator "NotIdentical":
--- Original
+++ New
@@ @@
if ([] !== $this->rulesets) {
$config['ruleset'] = array_map(static fn(Ruleset $rulesetConfig) => $rulesetConfig->toArray(), $this->rulesets);
}
- if ([] !== $this->skipViolations) {
+ if ([] === $this->skipViolations) {
$config['skip_violations'] = $this->skipViolations;
}
$config['ignore_uncovered_internal_classes'] = $this->ignoreUncoveredInternalClasses;
|
infection (ubuntu-24.04, 8.3):
src/Contract/Config/DeptracConfig.php#L153
Escaped Mutant for Mutator "ArrayOneItem":
--- Original
+++ New
@@ @@
}
$config['ignore_uncovered_internal_classes'] = $this->ignoreUncoveredInternalClasses;
$config['cache_file'] = $this->cacheFile;
- return $config;
+ return count($config) > 1 ? array_slice($config, 0, 1, true) : $config;
}
public function getExtensionAlias() : string
{
|
infection (ubuntu-24.04, 8.3):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L24
Escaped Mutant for Mutator "ArrayItemRemoval":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.3):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L25
Escaped Mutant for Mutator "DecrementInteger":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [ProcessEvent::class => ['invoke', -2]];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.3):
src/Core/Analyser/EventHandler/DependsOnDisallowedLayer.php#L25
Escaped Mutant for Mutator "IncrementInteger":
--- Original
+++ New
@@ @@
}
public static function getSubscribedEvents()
{
- return [ProcessEvent::class => ['invoke', -1]];
+ return [ProcessEvent::class => ['invoke', -0]];
}
public function invoke(ProcessEvent $event) : void
{
|
infection (ubuntu-24.04, 8.3):
src/Core/Analyser/EventHandler/DependsOnInternalToken.php#L50
Escaped Mutant for Mutator "MethodCallRemoval":
--- Original
+++ New
@@ @@
$isInternal = $event->dependentReference->hasTag($this->internalTag);
}
if ($isInternal) {
- $this->eventHelper->addSkippableViolation($event, $ruleset, $dependentLayer, $this);
+
$event->stopPropagation();
}
}
|
infection (ubuntu-24.04, 8.3)
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
deptrac (ubuntu-24.04, 8.3)
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
deptrac (ubuntu-24.04, 8.2)
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|
deptrac (ubuntu-24.04, 8.1)
The `set-output` command is deprecated and will be disabled soon. Please upgrade to using Environment Files. For more information see: https://github.blog/changelog/2022-10-11-github-actions-deprecating-save-state-and-set-output-commands/
|