Helpers for plugin authoring and static testing tool.
Package fp4php/functional
must be installed manually.
$ composer require --dev fp4php/functional fp4php/psalm-toolkit
$ vendor/bin/psalm-plugin enable fp4php/psalm-toolkit
At the moment you can use two methods for static asserts:
seePsalmIssue
: Checks that a code block from thehaveCode
have specific issue.seeReturnType
: Verifies a return type from thehaveCode
block.
Usage example below:
<?php
namespace Fp\Decode\Test\Static;
use Fp\PsalmToolkit\StaticTest\PsalmTest;
use Fp\PsalmToolkit\StaticTest\StaticTestCase;
use Fp\PsalmToolkit\StaticType\StaticTypes as t;
final class ExampleTest extends PsalmTest
{
public function __invoke(): void
{
StaticTestCase::describe('See InvalidScalarArgument issue')
->haveCode(function() {
$plus = fn(int $a, int $b): int => $a + $b;
$plus(10, 10.00);
})
->seePsalmIssue(
type: 'InvalidScalarArgument',
message: 'Argument 2 expects int, float(10) provided',
);
StaticTestCase::describe('See return type (invariant type compare)')
->haveCode(function() {
return [
'twenty' => 10 + 10,
'message' => 'Hello world!'
];
})
->seeReturnType(
is: t::shape([
'twenty' => t::literal(20),
'message' => t::literal('Hello world!'),
]),
);
StaticTestCase::describe('See return type (covariant type compare)')
->haveCode(function() {
return [
'twenty' => 10 + 10,
'message' => 'Hello world!'
];
})
->seeReturnType(
is: t::shape([
'twenty' => t::int(),
'message' => t::string(),
]),
invariant: false,
);
}
}