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 declare(strict_types=1); /** * This file is part of CodeIgniter 4 framework. * ..

Decoded Output download

<?php

declare(strict_types=1);

/**
 * This file is part of CodeIgniter 4 framework.
 *
 * (c) CodeIgniter Foundation <[email protected]>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

namespace CodeIgniter\Database\Builder;

use CodeIgniter\Test\CIUnitTestCase;
use CodeIgniter\Test\Mock\MockConnection;
use Config\Feature;
use PHPUnit\Framework\Attributes\Group;

/**
 * @internal
 */
#[Group('Others')]
final class GetTest extends CIUnitTestCase
{
    protected $db;

    protected function setUp(): void
    {
        parent::setUp();

        $this->db = new MockConnection([]);
    }

    public function testGet(): void
    {
        $builder = $this->db->table('users');

        $expectedSQL = 'SELECT * FROM "users"';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getCompiledSelect()));
    }

    /**
     * @see https://github.com/codeigniter4/CodeIgniter4/issues/2141
     */
    public function testGetWithReset(): void
    {
        $config                 = config(Feature::class);
        $config->limitZeroAsAll = false;

        $builder = $this->db->table('users');
        $builder->testMode()->where('username', 'bogus');

        $expectedSQL           = 'SELECT * FROM "users" WHERE "username" = \'bogus\'  LIMIT 50, 0';
        $expectedSQLafterreset = 'SELECT * FROM "users"  LIMIT 50, 0';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->get(0, 50, false)));
        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->get(0, 50, true)));
        $this->assertSame($expectedSQLafterreset, str_replace("
", ' ', $builder->get(0, 50, true)));
    }

    public function testGetWithResetWithLimitZeroAsAll(): void
    {
        $config                 = config(Feature::class);
        $config->limitZeroAsAll = true;

        $builder = $this->db->table('users');
        $builder->testMode()->where('username', 'bogus');

        $expectedSQL           = 'SELECT * FROM "users" WHERE "username" = \'bogus\'';
        $expectedSQLafterreset = 'SELECT * FROM "users"';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->get(0, 50, false)));
        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->get(0, 50, true)));
        $this->assertSame($expectedSQLafterreset, str_replace("
", ' ', $builder->get(0, 50, true)));
    }

    /**
     * @see https://github.com/codeigniter4/CodeIgniter4/issues/2143
     */
    public function testGetWhereWithLimit(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL             = 'SELECT * FROM "users" WHERE "username" = \'bogus\'  LIMIT 5';
        $expectedSQLWithoutReset = 'SELECT * FROM "users" WHERE "username" = \'bogus\' AND "username" = \'bogus\'  LIMIT 5';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], 5, null, false)));
        $this->assertSame($expectedSQLWithoutReset, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], 5, 0, true)));
        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], 5, null, true)));
    }

    public function testGetWhereWithLimitAndOffset(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL             = 'SELECT * FROM "users" WHERE "username" = \'bogus\'  LIMIT 10, 5';
        $expectedSQLWithoutReset = 'SELECT * FROM "users" WHERE "username" = \'bogus\' AND "username" = \'bogus\'  LIMIT 10, 5';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], 5, 10, false)));
        $this->assertSame($expectedSQLWithoutReset, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], 5, 10, true)));
        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], 5, 10, true)));
    }

    public function testGetWhereWithWhereConditionOnly(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL             = 'SELECT * FROM "users" WHERE "username" = \'bogus\'';
        $expectedSQLWithoutReset = 'SELECT * FROM "users" WHERE "username" = \'bogus\' AND "username" = \'bogus\'';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], null, null, false)));
        $this->assertSame($expectedSQLWithoutReset, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], null, null, true)));
        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(['username' => 'bogus'], null, null, true)));
    }

    public function testGetWhereWithoutArgs(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL = 'SELECT * FROM "users"';

        $this->assertSame($expectedSQL, str_replace("
", ' ', $builder->getWhere(null, null, null, true)));
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

declare(strict_types=1);

/**
 * This file is part of CodeIgniter 4 framework.
 *
 * (c) CodeIgniter Foundation <[email protected]>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

namespace CodeIgniter\Database\Builder;

use CodeIgniter\Test\CIUnitTestCase;
use CodeIgniter\Test\Mock\MockConnection;
use Config\Feature;
use PHPUnit\Framework\Attributes\Group;

/**
 * @internal
 */
#[Group('Others')]
final class GetTest extends CIUnitTestCase
{
    protected $db;

    protected function setUp(): void
    {
        parent::setUp();

        $this->db = new MockConnection([]);
    }

    public function testGet(): void
    {
        $builder = $this->db->table('users');

        $expectedSQL = 'SELECT * FROM "users"';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getCompiledSelect()));
    }

    /**
     * @see https://github.com/codeigniter4/CodeIgniter4/issues/2141
     */
    public function testGetWithReset(): void
    {
        $config                 = config(Feature::class);
        $config->limitZeroAsAll = false;

        $builder = $this->db->table('users');
        $builder->testMode()->where('username', 'bogus');

        $expectedSQL           = 'SELECT * FROM "users" WHERE "username" = \'bogus\'  LIMIT 50, 0';
        $expectedSQLafterreset = 'SELECT * FROM "users"  LIMIT 50, 0';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->get(0, 50, false)));
        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->get(0, 50, true)));
        $this->assertSame($expectedSQLafterreset, str_replace("\n", ' ', $builder->get(0, 50, true)));
    }

    public function testGetWithResetWithLimitZeroAsAll(): void
    {
        $config                 = config(Feature::class);
        $config->limitZeroAsAll = true;

        $builder = $this->db->table('users');
        $builder->testMode()->where('username', 'bogus');

        $expectedSQL           = 'SELECT * FROM "users" WHERE "username" = \'bogus\'';
        $expectedSQLafterreset = 'SELECT * FROM "users"';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->get(0, 50, false)));
        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->get(0, 50, true)));
        $this->assertSame($expectedSQLafterreset, str_replace("\n", ' ', $builder->get(0, 50, true)));
    }

    /**
     * @see https://github.com/codeigniter4/CodeIgniter4/issues/2143
     */
    public function testGetWhereWithLimit(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL             = 'SELECT * FROM "users" WHERE "username" = \'bogus\'  LIMIT 5';
        $expectedSQLWithoutReset = 'SELECT * FROM "users" WHERE "username" = \'bogus\' AND "username" = \'bogus\'  LIMIT 5';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], 5, null, false)));
        $this->assertSame($expectedSQLWithoutReset, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], 5, 0, true)));
        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], 5, null, true)));
    }

    public function testGetWhereWithLimitAndOffset(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL             = 'SELECT * FROM "users" WHERE "username" = \'bogus\'  LIMIT 10, 5';
        $expectedSQLWithoutReset = 'SELECT * FROM "users" WHERE "username" = \'bogus\' AND "username" = \'bogus\'  LIMIT 10, 5';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], 5, 10, false)));
        $this->assertSame($expectedSQLWithoutReset, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], 5, 10, true)));
        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], 5, 10, true)));
    }

    public function testGetWhereWithWhereConditionOnly(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL             = 'SELECT * FROM "users" WHERE "username" = \'bogus\'';
        $expectedSQLWithoutReset = 'SELECT * FROM "users" WHERE "username" = \'bogus\' AND "username" = \'bogus\'';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], null, null, false)));
        $this->assertSame($expectedSQLWithoutReset, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], null, null, true)));
        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(['username' => 'bogus'], null, null, true)));
    }

    public function testGetWhereWithoutArgs(): void
    {
        $builder = $this->db->table('users');
        $builder->testMode();

        $expectedSQL = 'SELECT * FROM "users"';

        $this->assertSame($expectedSQL, str_replace("\n", ' ', $builder->getWhere(null, null, null, true)));
    }
}

Function Calls

None

Variables

None

Stats

MD5 d3daa19e949ce16c44399ec26cf1f06a
Eval Count 0
Decode Time 130 ms