Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php /** * This file is part of the Zephir. * * (c) Phalcon Team <team@zephir-lang.co..
Decoded Output download
<?php
/**
* This file is part of the Zephir.
*
* (c) Phalcon Team <team@zephir-lang.com>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Zephir\Test\Logger\Formatter;
use PHPUnit\Framework\TestCase;
use Zephir\Config;
use Zephir\Logger\Formatter\CompilerFormatter;
use Zephir\Os;
final class CompilerFormatterTest extends TestCase
{
private Config $config;
protected function setUp(): void
{
$this->config = new Config();
}
public function testShouldBeQuietWhenConfigSilent(): void
{
$this->config->set('silent', true);
$compilerFormatter = new CompilerFormatter($this->config);
$this->assertSame('', $compilerFormatter->format([]), 'Should return empty string when Config have: silent=true');
}
public function getWarningContext(): array
{
return [
'message' => 'Variable "param1" declared but not used in test__closure::__invoke',
'context' => [
'unused-variable-external',
[
'type' => 'parameter',
'name' => 'param1',
'const' => 0,
'data-type' => 'variable',
'mandatory' => 0,
'reference' => 0,
'file' => realpath(\constant('FIXTURES_PATH').'/logger/closures.zep'),
'line' => 7,
'char' => 25,
],
],
'level' => 300,
'level_name' => 'WARNING',
'channel' => 'zephir',
'datetime' => new \DateTime(),
'extra' => [],
];
}
public function testShouldBeQuietForDisabledWarning(): void
{
// deny to print warnings for this category
$this->config->offsetSet(['warnings' => 'unused-variable-external'], false);
$compilerFormatter = new CompilerFormatter($this->config);
$this->assertSame('', $compilerFormatter->format($this->getWarningContext()));
}
public function testShouldFormatWarningForCategory(): void
{
if (Os::isWindows()) {
$this->markTestSkipped('Warning: Strings contain different line endings!');
}
// allow to print warnings for this category
$this->config->offsetSet(['warnings' => 'unused-variable-external'], true);
$compilerFormatter = new CompilerFormatter($this->config);
$testContext = $this->getWarningContext();
$filePath = $testContext['context'][1]['file'];
$expected = " Warning: Variable \"param1\" declared but not used in test\3__closure::__invoke in {$filePath} on line 7 [unused-variable-external]
".
" return function(param1) {
".
" ------------------------^
";
$this->assertSame($expected, $compilerFormatter->format($testContext));
unset($testContext['context'][1]['file']);
$expected = ' Warning: Variable "param1" declared but not used in test__closure::__invoke in unknown on line 0 [unused-variable-external]'.PHP_EOL;
$this->assertSame($expected, $compilerFormatter->format($testContext));
}
public function testShouldFormatWithStripInfoLevels(): void
{
$this->config->offsetSet(['warnings' => 'unused-variable-external'], true);
$compilerFormatter = new CompilerFormatter($this->config);
$testContext = $this->getWarningContext();
$testContext['level_name'] = 'INFO';
unset($testContext['context'][1]['file']);
$expected = " Variable \"param1\" declared but not used in test\3__closure::__invoke in unknown on line 0 [unused-variable-external]
";
$this->assertSame($expected, $compilerFormatter->format($testContext));
}
}
?>
Did this file decode correctly?
Original Code
<?php
/**
* This file is part of the Zephir.
*
* (c) Phalcon Team <team@zephir-lang.com>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Zephir\Test\Logger\Formatter;
use PHPUnit\Framework\TestCase;
use Zephir\Config;
use Zephir\Logger\Formatter\CompilerFormatter;
use Zephir\Os;
final class CompilerFormatterTest extends TestCase
{
private Config $config;
protected function setUp(): void
{
$this->config = new Config();
}
public function testShouldBeQuietWhenConfigSilent(): void
{
$this->config->set('silent', true);
$compilerFormatter = new CompilerFormatter($this->config);
$this->assertSame('', $compilerFormatter->format([]), 'Should return empty string when Config have: silent=true');
}
public function getWarningContext(): array
{
return [
'message' => 'Variable "param1" declared but not used in test\3__closure::__invoke',
'context' => [
'unused-variable-external',
[
'type' => 'parameter',
'name' => 'param1',
'const' => 0,
'data-type' => 'variable',
'mandatory' => 0,
'reference' => 0,
'file' => realpath(\constant('FIXTURES_PATH').'/logger/closures.zep'),
'line' => 7,
'char' => 25,
],
],
'level' => 300,
'level_name' => 'WARNING',
'channel' => 'zephir',
'datetime' => new \DateTime(),
'extra' => [],
];
}
public function testShouldBeQuietForDisabledWarning(): void
{
// deny to print warnings for this category
$this->config->offsetSet(['warnings' => 'unused-variable-external'], false);
$compilerFormatter = new CompilerFormatter($this->config);
$this->assertSame('', $compilerFormatter->format($this->getWarningContext()));
}
public function testShouldFormatWarningForCategory(): void
{
if (Os::isWindows()) {
$this->markTestSkipped('Warning: Strings contain different line endings!');
}
// allow to print warnings for this category
$this->config->offsetSet(['warnings' => 'unused-variable-external'], true);
$compilerFormatter = new CompilerFormatter($this->config);
$testContext = $this->getWarningContext();
$filePath = $testContext['context'][1]['file'];
$expected = " Warning: Variable \"param1\" declared but not used in test\\3__closure::__invoke in {$filePath} on line 7 [unused-variable-external]\n\n".
"\t return function(param1) {\n\n".
"\t------------------------^\n";
$this->assertSame($expected, $compilerFormatter->format($testContext));
unset($testContext['context'][1]['file']);
$expected = ' Warning: Variable "param1" declared but not used in test\3__closure::__invoke in unknown on line 0 [unused-variable-external]'.PHP_EOL;
$this->assertSame($expected, $compilerFormatter->format($testContext));
}
public function testShouldFormatWithStripInfoLevels(): void
{
$this->config->offsetSet(['warnings' => 'unused-variable-external'], true);
$compilerFormatter = new CompilerFormatter($this->config);
$testContext = $this->getWarningContext();
$testContext['level_name'] = 'INFO';
unset($testContext['context'][1]['file']);
$expected = " Variable \"param1\" declared but not used in test\\3__closure::__invoke in unknown on line 0 [unused-variable-external]\n";
$this->assertSame($expected, $compilerFormatter->format($testContext));
}
}
Function Calls
None |
Stats
MD5 | 1a6d20d8c779b83e687dab8a44c1c0b5 |
Eval Count | 0 |
Decode Time | 84 ms |