phpOMS/tests/Security/PhpCodeTest.php
2022-12-16 21:59:21 +01:00

143 lines
3.9 KiB
PHP
Executable File

<?php
/**
* Karaka
*
* PHP Version 8.1
*
* @package tests
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link https://jingga.app
*/
declare(strict_types=1);
namespace phpOMS\tests\Security;
require_once __DIR__ . '/../Autoloader.php';
use phpOMS\Security\PhpCode;
/**
* @testdox phpOMS\tests\Security\PhpCodeTest: Basic php source code security inspection
*
* @internal
*/
final class PhpCodeTest extends \PHPUnit\Framework\TestCase
{
/**
* @testdox A file with unicode characters gets correctly identified
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testHasUnicode() : void
{
self::assertTrue(
PhpCode::hasUnicode(
PhpCode::normalizeSource(
\file_get_contents(__DIR__ . '/Sample/hasUnicode.php')
)
)
);
}
/**
* @testdox A file with no unicode characters gets correctly identified
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testHasNoUnicode() : void
{
self::assertFalse(
PhpCode::hasUnicode(
PhpCode::normalizeSource(
\file_get_contents(__DIR__ . '/Sample/noUnicode.php')
)
)
);
}
/**
* @testdox A file with no disabled functions gets correctly identified
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testDisabledFunctions() : void
{
self::assertFalse(PhpCode::isDisabled(['file_get_contents']));
self::assertFalse(PhpCode::isDisabled(['eval', 'file_get_contents']));
}
/**
* @testdox A file with deprecated functions gets correctly identified
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testHasDeprecatedFunction() : void
{
self::assertTrue(
PhpCode::hasDeprecatedFunction(
PhpCode::normalizeSource(
\file_get_contents(__DIR__ . '/Sample/hasDeprecated.php')
)
)
);
}
/**
* @testdox A file with no deprecated functions gets correctly identified
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testHasNoDeprecatedFunction() : void
{
self::assertFalse(
PhpCode::hasDeprecatedFunction(
PhpCode::normalizeSource(
\file_get_contents(__DIR__ . '/Sample/noDeprecated.php')
)
)
);
}
/**
* @testdox A file hash comparison is successful if the file generates the same hash
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testFileIntegrity() : void
{
self::assertTrue(PhpCode::validateFileIntegrity(__DIR__ . '/Sample/hasDeprecated.php', \md5_file(__DIR__ . '/Sample/hasDeprecated.php')));
}
/**
* @testdox A file hash comparison is unsuccessful if the file generates a different hash
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testFileInvalidIntegrity() : void
{
self::assertFalse(PhpCode::validateFileIntegrity(__DIR__ . '/Sample/hasUnicode.php', \md5_file(__DIR__ . '/Sample/hasDeprecated.php')));
}
/**
* @testdox Two equal strings validate as the same
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testStringIntegrity() : void
{
self::assertTrue(PhpCode::validateStringIntegrity('aa', 'aa'));
}
/**
* @testdox Two different strings don't validate as the same
* @covers phpOMS\Security\PhpCode
* @group framework
*/
public function testStringInvalidIntegrity() : void
{
self::assertFalse(PhpCode::validateStringIntegrity('aa', 'aA'));
}
}