mirror of
https://github.com/danog/psalm.git
synced 2025-01-22 13:51:54 +01:00
f439d6550b
* Transformation that updates assertions * Simplify transformation * Ensure that all tests have keys * Fix a few remaining keys
303 lines
10 KiB
PHP
303 lines
10 KiB
PHP
<?php
|
|
|
|
namespace Psalm\Tests\FileManipulation;
|
|
|
|
class MissingPropertyTypeTest extends FileManipulationTestCase
|
|
{
|
|
/**
|
|
* @return array<string,array{input:string,output:string,php_version:string,issues_to_fix:array<string>,safe_types:bool,allow_backwards_incompatible_changes?:bool}>
|
|
*/
|
|
public function providerValidCodeParse(): array
|
|
{
|
|
return [
|
|
'addMissingUnionType56' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
} else {
|
|
$this->v = "hello";
|
|
}
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
/**
|
|
* @var int|string
|
|
*
|
|
* @psalm-var \'hello\'|4
|
|
*/
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
} else {
|
|
$this->v = "hello";
|
|
}
|
|
}
|
|
}',
|
|
'php_version' => '5.6',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingNullableType56' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
}
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
/**
|
|
* @var int|null
|
|
*
|
|
* @psalm-var 4|null
|
|
*/
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
}
|
|
}
|
|
}',
|
|
'php_version' => '5.6',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingNullableTypeNoDefault74' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
}
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
/**
|
|
* @var int|null
|
|
*
|
|
* @psalm-var 4|null
|
|
*/
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
}
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingNullableTypeWithDefault74' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $v = null;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
}
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
public ?int $v = null;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
}
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingUnionTypeSetInBranches74' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
} else {
|
|
$this->v = "hello";
|
|
}
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
/**
|
|
* @var int|string
|
|
*
|
|
* @psalm-var \'hello\'|4
|
|
*/
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
} else {
|
|
$this->v = "hello";
|
|
}
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingIntTypeSetInBranches74' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
} else {
|
|
$this->v = 20;
|
|
}
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
public int $v;
|
|
|
|
public function __construct() {
|
|
if (rand(0, 1)) {
|
|
$this->v = 4;
|
|
} else {
|
|
$this->v = 20;
|
|
}
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingDocblockTypesSpacedProperly' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $u;
|
|
public $v;
|
|
|
|
public function __construct(int $i, int $j) {
|
|
$this->u = $i;
|
|
$this->v = $j;
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
/**
|
|
* @var int
|
|
*/
|
|
public $u;
|
|
|
|
/**
|
|
* @var int
|
|
*/
|
|
public $v;
|
|
|
|
public function __construct(int $i, int $j) {
|
|
$this->u = $i;
|
|
$this->v = $j;
|
|
}
|
|
}',
|
|
'php_version' => '7.1',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingTypehintsSpacedProperly' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $u;
|
|
public $v;
|
|
|
|
public function __construct(int $i, int $j) {
|
|
$this->u = $i;
|
|
$this->v = $j;
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
public int $u;
|
|
public int $v;
|
|
|
|
public function __construct(int $i, int $j) {
|
|
$this->u = $i;
|
|
$this->v = $j;
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'addMissingTypehintWithDefault' => [
|
|
'input' => '<?php
|
|
class A {
|
|
public $u = false;
|
|
|
|
public function bar() {
|
|
$this->u = true;
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
class A {
|
|
public bool $u = false;
|
|
|
|
public function bar() {
|
|
$this->u = true;
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
'dontAddMissingPropertyTypeInTrait' => [
|
|
'input' => '<?php
|
|
trait T {
|
|
public $u;
|
|
}
|
|
class A {
|
|
use T;
|
|
|
|
public function bar() {
|
|
$this->u = 5;
|
|
}
|
|
}',
|
|
'output' => '<?php
|
|
trait T {
|
|
public $u;
|
|
}
|
|
class A {
|
|
use T;
|
|
|
|
public function bar() {
|
|
$this->u = 5;
|
|
}
|
|
}',
|
|
'php_version' => '7.4',
|
|
'issues_to_fix' => ['MissingPropertyType'],
|
|
'safe_types' => true,
|
|
],
|
|
];
|
|
}
|
|
}
|