1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-06 04:59:14 +01:00
psalm/tests/ForbiddenCodeTest.php

381 lines
11 KiB
PHP
Raw Normal View History

2016-12-12 05:41:11 +01:00
<?php
2023-10-19 13:12:06 +02:00
declare(strict_types=1);
2016-12-12 05:41:11 +01:00
namespace Psalm\Tests;
use Psalm\Config;
use Psalm\Context;
2021-12-03 20:29:06 +01:00
use Psalm\Exception\CodeException;
2021-12-03 20:11:20 +01:00
use Psalm\Internal\Analyzer\ProjectAnalyzer;
use Psalm\Internal\Provider\Providers;
2021-12-04 21:55:53 +01:00
use Psalm\Tests\Internal\Provider\FakeParserCacheProvider;
use Psalm\Tests\Traits\InvalidCodeAnalysisTestTrait;
use Psalm\Tests\Traits\ValidCodeAnalysisTestTrait;
use function dirname;
use function getcwd;
class ForbiddenCodeTest extends TestCase
2016-12-12 05:41:11 +01:00
{
2021-12-04 21:55:53 +01:00
use InvalidCodeAnalysisTestTrait;
use ValidCodeAnalysisTestTrait;
2016-12-12 05:41:11 +01:00
public function providerInvalidCodeParse(): iterable
2016-12-12 05:41:11 +01:00
{
return [
'varDump' => [
'code' => '<?php
var_dump("hello");',
2017-05-27 02:05:57 +02:00
'error_message' => 'ForbiddenCode',
],
'varDumpCased' => [
'code' => '<?php
vAr_dUMp("hello");',
'error_message' => 'ForbiddenCode',
],
'execTicks' => [
'code' => '<?php
`rm -rf`;',
2017-05-27 02:05:57 +02:00
'error_message' => 'ForbiddenCode',
],
'exec' => [
'code' => '<?php
shell_exec("rm -rf");',
2017-05-27 02:05:57 +02:00
'error_message' => 'ForbiddenCode',
],
'execCased' => [
'code' => '<?php
sHeLl_EXeC("rm -rf");',
'error_message' => 'ForbiddenCode',
],
];
2016-12-12 05:41:11 +01:00
}
public function providerValidCodeParse(): iterable
{
return [
'execWithSuppression' => [
'code' => '<?php
@exec("pwd 2>&1", $output, $returnValue);
if ($returnValue === 0) {
echo "success";
}',
],
'execWithoutSuppression' => [
'code' => '<?php
exec("pwd 2>&1", $output, $returnValue);
if ($returnValue === 0) {
echo "success";
}',
],
];
}
public function testAllowedEchoFunction(): void
{
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
2022-12-18 17:15:15 +01:00
<psalm></psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
2022-12-18 17:15:15 +01:00
echo "hello";',
);
$this->analyzeFile($file_path, new Context());
}
2022-01-18 18:25:18 +01:00
public function testForbiddenCodeFunctionViaFunctions(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="echo" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
2022-12-18 17:15:15 +01:00
echo "hello";',
);
$this->analyzeFile($file_path, new Context());
}
public function testAllowedPrintFunction(): void
{
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
2022-12-18 17:15:15 +01:00
<psalm></psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
2022-12-18 17:15:15 +01:00
print "hello";',
);
$this->analyzeFile($file_path, new Context());
}
public function testForbiddenPrintFunction(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="print" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
2022-12-18 17:15:15 +01:00
print "hello";',
);
$this->analyzeFile($file_path, new Context());
}
public function testAllowedVarExportFunction(): void
{
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
2022-12-18 17:15:15 +01:00
<psalm></psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
$a = [1, 2, 3];
2022-12-18 17:15:15 +01:00
var_export($a);',
);
$this->analyzeFile($file_path, new Context());
}
public function testForbiddenVarExportFunction(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="var_export" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
$a = [1, 2, 3];
2022-12-18 17:15:15 +01:00
var_export($a);',
);
$this->analyzeFile($file_path, new Context());
}
public function testNoExceptionWithMatchingNameButDifferentNamespace(): void
{
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
<<<'XML'
<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="strlen"/>
</forbiddenFunctions>
</psalm>
XML,
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
<<<'PHP'
<?php
namespace Foo {
function strlen(): int {
return 0;
}
}
namespace {
use function Foo\strlen;
strlen();
}
PHP,
);
$this->analyzeFile($file_path, new Context());
}
public function testForbiddenEmptyFunction(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="empty" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
2022-12-18 17:15:15 +01:00
empty(false);',
);
$this->analyzeFile($file_path, new Context());
}
2021-10-31 02:02:16 +02:00
public function testForbiddenExitFunction(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
2021-10-31 02:02:16 +02:00
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="exit" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
2021-10-31 02:02:16 +02:00
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
2021-10-31 02:02:16 +02:00
$this->addFile(
$file_path,
'<?php
exit(2);
2022-12-18 17:15:15 +01:00
',
2021-10-31 02:02:16 +02:00
);
$this->analyzeFile($file_path, new Context());
}
public function testForbiddenDieFunction(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
2021-10-31 02:02:16 +02:00
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="die" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
2021-10-31 02:02:16 +02:00
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
2021-10-31 02:02:16 +02:00
$this->addFile(
$file_path,
'<?php
die(2);
2022-12-18 17:15:15 +01:00
',
2021-10-31 02:02:16 +02:00
);
$this->analyzeFile($file_path, new Context());
}
public function testForbiddenEvalExpression(): void
{
$this->expectExceptionMessage('ForbiddenCode');
2021-12-03 20:29:06 +01:00
$this->expectException(CodeException::class);
$this->project_analyzer = $this->getProjectAnalyzerWithConfig(
TestConfig::loadFromXML(
dirname(__DIR__, 2),
'<?xml version="1.0"?>
<psalm>
<forbiddenFunctions>
<function name="eval" />
</forbiddenFunctions>
2022-12-18 17:15:15 +01:00
</psalm>',
),
);
2023-10-09 22:40:21 +02:00
$file_path = (string) getcwd() . '/src/somefile.php';
$this->addFile(
$file_path,
'<?php
eval("foo bar");
2022-12-18 17:15:15 +01:00
',
);
$this->analyzeFile($file_path, new Context());
}
2021-10-31 02:02:16 +02:00
2021-12-03 20:11:20 +01:00
private function getProjectAnalyzerWithConfig(Config $config): ProjectAnalyzer
{
2021-12-03 20:11:20 +01:00
$p = new ProjectAnalyzer(
$config,
2021-12-03 20:11:20 +01:00
new Providers(
$this->file_provider,
2022-12-18 17:15:15 +01:00
new FakeParserCacheProvider(),
),
);
$p->setPhpVersion('7.4', 'tests');
return $p;
}
2016-12-12 05:41:11 +01:00
}