1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-30 04:39:00 +01:00
psalm/tests/ClassLoadOrderTest.php

157 lines
4.4 KiB
PHP
Raw Normal View History

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
<?php
namespace Psalm\Tests;
class ClassLoadOrderTest extends TestCase
{
use Traits\FileCheckerInvalidCodeParseTestTrait;
use Traits\FileCheckerValidCodeParseTestTrait;
/**
* @return array
*/
public function providerFileCheckerValidCodeParse()
{
return [
'singleFileInheritance' => [
'<?php
class A extends B {}
class B {
public function fooFoo() : void {
$a = new A();
$a->barBar();
}
protected function barBar() : void {
echo "hello";
}
}',
],
'constSandwich' => [
'<?php
class A { const B = 42;}
$a = A::B;
class C {}',
],
'SKIPPED-deferredReference' => [
'<?php
class B {
const C = A;
}
const A = 5;
$a = B::C;',
'assertions' => [
'$a' => 'int',
],
],
'moreCyclicalReferences' => [
'<?php
class B extends C {
public function d() : A {
return new A;
}
}
class C {
/** @var string */
public $p = A::class;
public static function e() : void {}
}
class A extends B {
private function f() : void {
self::e();
}
}',
],
'referenceToSubclassInMethod' => [
'<?php
class A {
public function b(B $b) : void {
}
public function c() : void {
}
}
class B extends A {
public function d() : void {
$this->c();
}
}',
],
'referenceToClassInMethod' => [
'<?php
class A {
public function b(A $b) : void {
$b->b(new A());
}
}',
],
'classTraversal' => [
'<?php
namespace Foo;
class A {
/** @var string */
protected $foo = C::DOPE;
/** @return string */
public function __get() { }
}
class B extends A {
/** @return void */
public function foo() {
echo (string)(new C)->bar;
}
}
class C extends B {
const DOPE = "dope";
}',
],
];
}
/**
* @return array
*/
public function providerFileCheckerInvalidCodeParse()
{
return [
'inheritanceLoopOne' => [
'<?php
class C extends C {}',
'error_message' => 'Circular reference',
],
'inheritanceLoopTwo' => [
'<?php
class E extends F {}
class F extends E {}',
'error_message' => 'Circular reference',
],
'inheritanceLoopThree' => [
'<?php
class G extends H {}
class H extends I {}
class I extends G {}',
'error_message' => 'Circular reference',
],
'SKIPPED-invalidDeferredReference' => [
'<?php
class B {
const C = A;
}
$b = (new B);
const A = 5;',
'error_message' => 'UndefinedConstant',
],
];
}
}