1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-27 04:45:20 +01:00
psalm/tests/MethodCallTest.php

205 lines
6.3 KiB
PHP
Raw Normal View History

2016-12-12 05:41:11 +01:00
<?php
namespace Psalm\Tests;
class MethodCallTest extends TestCase
2016-12-12 05:41:11 +01:00
{
use Traits\FileCheckerInvalidCodeParseTestTrait;
use Traits\FileCheckerValidCodeParseTestTrait;
2016-12-17 04:16:29 +01:00
/**
* @return array
2016-12-17 04:16:29 +01:00
*/
public function providerFileCheckerValidCodeParse()
2016-12-17 04:16:29 +01:00
{
return [
'notInCallMapTest' => [
'<?php
Refactor scanning and analysis, introducing multithreading (#191) * Add failing test * Add visitor to soup up classlike references * Move a whole bunch of code into the visitor * Move some methods back, move onto analysis stage * Use the getAliases method everywhere * Fix refs * Fix more refs * Fix some tests * Fix more tests * Fix include tests * Shift config class finding to project checker and fix bugs * Fix a few more tests * transition test to new syntax * Remove var_dump * Delete a bunch of code and fix mutation test * Remove unnecessary visitation * Transition to better mocked out file provider, breaking some cached statement loading * Use different scheme for naming anonymous classes * Fix anonymous class issues * Refactor file/statement loading * Add specific property types * Fix mapped property assignment * Improve how we deal with traits * Fix trait checking * Pass Psalm checks * Add multi-process support * Delay console output until the end * Remove PHP 7 syntax * Update file storage with classes * Fix scanning individual files and add reflection return types * Always turn XDebug off * Add quicker method of getting method mutations * Queue return types for crawling * Interpret all strings as possible classes once we see a `get_class` call * Check invalid return types again * Fix template namespacing issues * Default to class-insensitive file names for includes * Don’t overwrite existing issues data * Add var docblocks for scanning * Add null check * Fix loading of external classes in templates * Only try to populate class when we haven’t yet seen it’s not a class * Fix trait property accessibility * Only ever improve docblock param type * Make param replacement more robust * Fix static const missing inferred type * Fix a few more tests * Register constant definitions * Fix trait aliasing * Skip constant type tests for now * Fix linting issues * Make sure caching is off for tests * Remove unnecessary return * Use emulative parser if on PHP 5.6 * Cache parser for faster first-time parse * Fix constant resolution when scanning classes * Remove test that’s beyond a practical scope * Add back --diff support * Add --help for --threads * Remove unused vars
2017-07-25 22:11:02 +02:00
new DOMImplementation();',
],
'parentStaticCall' => [
'<?php
class A {
/** @return void */
public static function foo(){}
}
class B extends A {
/** @return void */
public static function bar(){
parent::foo();
}
2017-05-27 02:05:57 +02:00
}',
],
'nonStaticInvocation' => [
'<?php
class Foo {
public static function barBar() : void {}
}
2017-05-27 02:05:57 +02:00
(new Foo())->barBar();',
],
'staticInvocation' => [
'<?php
class A {
public static function fooFoo() : void {}
}
class B extends A {
}
2017-05-27 02:05:57 +02:00
B::fooFoo();',
],
'staticCallOnVar' => [
'<?php
class A {
public static function bar() : int {
return 5;
}
}
$foo = new A;
$b = $foo::bar();',
],
'uppercasedSelf' => [
'<?php
class X33{
public static function main() : void {
echo SELF::class . "\n"; // Class or interface SELF does not exist
}
}
X33::main();',
],
];
2016-12-17 04:16:29 +01:00
}
/**
* @return array
*/
public function providerFileCheckerInvalidCodeParse()
{
return [
'staticInvocation' => [
'<?php
class Foo {
public function barBar() : void {}
}
Foo::barBar();',
2017-05-27 02:05:57 +02:00
'error_message' => 'InvalidStaticInvocation',
],
'parentStaticCall' => [
'<?php
class A {
/** @return void */
public function foo(){}
}
class B extends A {
/** @return void */
public static function bar(){
parent::foo();
}
}',
2017-05-27 02:05:57 +02:00
'error_message' => 'InvalidStaticInvocation',
],
'mixedMethodCall' => [
'<?php
class Foo {
public static function barBar() : void {}
}
/** @var mixed */
$a = (new Foo());
$a->barBar();',
'error_message' => 'MixedMethodCall',
'error_levels' => [
'MissingPropertyType',
2017-05-27 02:05:57 +02:00
'MixedAssignment',
],
],
'invalidMethodCall' => [
'<?php
("hello")->someMethod();',
'error_message' => 'InvalidMethodCall',
],
'possiblyInvalidMethodCall' => [
'<?php
class A1 {
public function methodOfA(): void {
}
}
/** @param A1|string $x */
function example($x, bool $isObject) {
if ($isObject) {
$x->methodOfA();
}
}',
'error_message' => 'PossiblyInvalidMethodCall',
],
'selfNonStaticInvocation' => [
'<?php
class A {
public function fooFoo() : void {}
public function barBar() : void {
self::fooFoo();
}
}',
2017-05-27 02:05:57 +02:00
'error_message' => 'NonStaticSelfCall',
],
'noParent' => [
'<?php
class Foo {
public function barBar() : void {
parent::barBar();
}
}',
2017-05-27 02:05:57 +02:00
'error_message' => 'ParentNotFound',
],
'coercedClass' => [
'<?php
class NullableClass {
}
class NullableBug {
/**
* @param string $className
* @return object|null
*/
public static function mock($className) {
if (!$className) { return null; }
return new $className();
}
/**
* @return NullableClass
*/
public function returns_nullable_class() {
return self::mock("NullableClass");
}
}',
'error_message' => 'LessSpecificReturnStatement',
2017-05-27 02:05:57 +02:00
'error_levels' => ['MixedInferredReturnType'],
],
'undefinedVariableStaticCall' => [
'<?php
$foo::bar();',
'error_message' => 'UndefinedGlobalVariable',
],
'staticCallOnString' => [
'<?php
class A {
public static function bar() : int {
return 5;
}
}
$foo = "A";
$b = $foo::bar();',
'error_message' => 'MixedAssignment',
],
];
}
2016-12-12 05:41:11 +01:00
}