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

Variables

None

Stats

MD5 1a6d20d8c779b83e687dab8a44c1c0b5
Eval Count 0
Decode Time 84 ms