1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 13:51:54 +01:00
psalm/tests/FunctionCallTest.php

273 lines
7.4 KiB
PHP
Raw Normal View History

2016-12-11 23:41:11 -05:00
<?php
namespace Psalm\Tests;
use PhpParser\ParserFactory;
use PHPUnit_Framework_TestCase;
use Psalm\Checker\FileChecker;
use Psalm\Config;
use Psalm\Context;
class FunctionCallTest extends PHPUnit_Framework_TestCase
{
/** @var \PhpParser\Parser */
2016-12-11 23:41:11 -05:00
protected static $parser;
/** @var \Psalm\Checker\ProjectChecker */
protected $project_checker;
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
2016-12-11 23:41:11 -05:00
public static function setUpBeforeClass()
{
self::$parser = (new ParserFactory)->create(ParserFactory::PREFER_PHP7);
}
2016-12-11 23:41:11 -05:00
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
public function setUp()
{
2016-12-14 12:28:38 -05:00
$config = new TestConfig();
2016-12-11 23:41:11 -05:00
FileChecker::clearCache();
$this->project_checker = new \Psalm\Checker\ProjectChecker();
2016-12-11 23:41:11 -05:00
}
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2016-12-11 23:41:11 -05:00
* @expectedExceptionMessage InvalidScalarArgument
2017-01-13 14:07:23 -05:00
* @return void
2016-12-11 23:41:11 -05:00
*/
public function testInvalidScalarArgument()
{
$stmts = self::$parser->parse('<?php
2016-12-30 13:09:00 -05:00
function fooFoo(int $a) : void {}
fooFoo("string");
2016-12-11 23:41:11 -05:00
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2016-12-11 23:41:11 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2016-12-11 23:41:11 -05:00
}
2016-12-14 19:24:33 -05:00
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2016-12-14 19:24:33 -05:00
* @expectedExceptionMessage MixedArgument
2017-01-13 14:07:23 -05:00
* @return void
2016-12-14 19:24:33 -05:00
*/
public function testMixedArgument()
{
2016-12-29 20:07:42 -05:00
Config::getInstance()->setCustomErrorLevel('MixedAssignment', Config::REPORT_SUPPRESS);
2016-12-14 19:24:33 -05:00
$stmts = self::$parser->parse('<?php
2016-12-30 13:09:00 -05:00
function fooFoo(int $a) : void {}
2016-12-14 19:24:33 -05:00
/** @var mixed */
$a = "hello";
2016-12-30 13:09:00 -05:00
fooFoo($a);
2016-12-14 19:24:33 -05:00
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2016-12-14 19:24:33 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2016-12-14 19:24:33 -05:00
}
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2016-12-14 19:24:33 -05:00
* @expectedExceptionMessage NullArgument
2017-01-13 14:07:23 -05:00
* @return void
2016-12-14 19:24:33 -05:00
*/
public function testNullArgument()
{
$stmts = self::$parser->parse('<?php
2016-12-30 13:09:00 -05:00
function fooFoo(int $a) : void {}
fooFoo(null);
2016-12-14 19:24:33 -05:00
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2016-12-14 19:24:33 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2016-12-14 19:24:33 -05:00
}
2016-12-16 22:16:29 -05:00
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2016-12-16 22:16:29 -05:00
* @expectedExceptionMessage TooFewArguments
2017-01-13 14:07:23 -05:00
* @return void
2016-12-16 22:16:29 -05:00
*/
public function testTooFewArguments()
{
$stmts = self::$parser->parse('<?php
2016-12-30 13:09:00 -05:00
function fooFoo(int $a) : void {}
fooFoo();
2016-12-16 22:16:29 -05:00
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2016-12-16 22:16:29 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2016-12-16 22:16:29 -05:00
}
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2016-12-16 22:16:29 -05:00
* @expectedExceptionMessage TooManyArguments
2017-01-13 14:07:23 -05:00
* @return void
2016-12-16 22:16:29 -05:00
*/
public function testTooManyArguments()
{
$stmts = self::$parser->parse('<?php
2016-12-30 13:09:00 -05:00
function fooFoo(int $a) : void {}
fooFoo(5, "dfd");
2016-12-16 22:16:29 -05:00
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2016-12-16 22:16:29 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2016-12-16 22:16:29 -05:00
}
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2016-12-16 22:16:29 -05:00
* @expectedExceptionMessage TypeCoercion
2017-01-13 14:07:23 -05:00
* @return void
2016-12-16 22:16:29 -05:00
*/
public function testTypeCoercion()
{
$stmts = self::$parser->parse('<?php
class A {}
class B extends A{}
2016-12-30 13:09:00 -05:00
function fooFoo(B $b) : void {}
fooFoo(new A());
2016-12-16 22:16:29 -05:00
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2016-12-16 22:16:29 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2016-12-16 22:16:29 -05:00
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
public function testTypedArrayWithDefault()
{
$stmts = self::$parser->parse('<?php
class A {}
/** @param array<A> $a */
function fooFoo(array $a = []) : void {
}
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
}
2017-01-02 01:20:47 -05:00
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
2017-01-02 01:20:47 -05:00
* @expectedExceptionMessage DuplicateParam
2017-01-13 14:07:23 -05:00
* @return void
2017-01-02 01:20:47 -05:00
*/
public function testDuplicateParam()
{
$stmts = self::$parser->parse('<?php
function f($p, $p) {}
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
}
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
public function testByRef()
{
$stmts = self::$parser->parse('<?php
function fooFoo(string &$v) : void {}
fooFoo($a);
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
}
/**
2017-01-13 14:07:23 -05:00
* @expectedException \Psalm\Exception\CodeException
* @expectedExceptionMessage InvalidPassByReference
2017-01-13 14:07:23 -05:00
* @return void
*/
public function testBadByRef()
{
$this->markTestIncomplete('Does not throw an error');
$stmts = self::$parser->parse('<?php
function fooFoo(string &$v) : void {}
fooFoo("a");
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
2017-01-02 01:20:47 -05:00
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
2017-01-02 01:20:47 -05:00
}
2017-01-12 09:42:24 -05:00
2017-01-13 14:07:23 -05:00
/**
* @return void
*/
2017-01-12 09:42:24 -05:00
public function testNamespaced()
{
$stmts = self::$parser->parse('<?php
namespace A;
/** @return void */
function f(int $p) {}
2017-01-12 09:42:24 -05:00
f(5);
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
}
/**
* @return void
*/
public function testNamespacedRootFunctionCall()
{
$stmts = self::$parser->parse('<?php
namespace {
/** @return void */
function foo() { }
}
namespace A\B\C {
foo();
}
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
}
/**
* @return void
*/
public function testNamespacedAliasedFunctionCall()
{
$stmts = self::$parser->parse('<?php
namespace Aye {
/** @return void */
function foo() { }
}
namespace Bee {
use Aye as A;
A\foo();
}
');
$file_checker = new FileChecker('somefile.php', $this->project_checker, $stmts);
$context = new Context('somefile.php');
$file_checker->visitAndAnalyzeMethods($context);
}
2016-12-11 23:41:11 -05:00
}