Skip to content

Commit

Permalink
Add test for Mysqli\Result
Browse files Browse the repository at this point in the history
  • Loading branch information
phansys committed Jun 5, 2023
1 parent 01c4ce1 commit bad8621
Show file tree
Hide file tree
Showing 2 changed files with 100 additions and 0 deletions.
1 change: 1 addition & 0 deletions phpcs.xml.dist
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,7 @@
-->
<exclude-pattern>src/Driver/IBMDB2/Connection.php</exclude-pattern>
<exclude-pattern>src/Driver/Mysqli/Exception/ConnectionFailed.php</exclude-pattern>
<exclude-pattern>tests/Functional/Driver/Mysqli/ResultTest.php</exclude-pattern>
</rule>

<!-- See https://github.com/squizlabs/PHP_CodeSniffer/issues/2837 -->
Expand Down
99 changes: 99 additions & 0 deletions tests/Functional/Driver/Mysqli/ResultTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
<?php

declare(strict_types=1);

namespace Doctrine\DBAL\Tests\Functional\Driver\Mysqli;

use Doctrine\DBAL\Driver\Mysqli\Result;
use Doctrine\DBAL\Schema\Table;
use Doctrine\DBAL\Tests\FunctionalTestCase;
use Doctrine\DBAL\Tests\TestUtil;
use mysqli;
use mysqli_driver;
use mysqli_sql_exception;

use function assert;
use function sprintf;

use const MYSQLI_REPORT_ERROR;
use const MYSQLI_REPORT_OFF;
use const MYSQLI_REPORT_STRICT;

/** @requires extension mysqli */
final class ResultTest extends FunctionalTestCase
{
private const TABLE_NAME = 'result_test_table';

private mysqli $nativeConnection;

protected function setUp(): void
{
if (! TestUtil::isDriverOneOf('mysqli')) {
self::markTestSkipped('This test requires the mysqli driver.');

return;
}

$nativeConnection = $this->connection->getNativeConnection();

assert($nativeConnection instanceof mysqli);

$this->nativeConnection = $nativeConnection;

$table = new Table(self::TABLE_NAME);
$table->addColumn('my_col_1', 'integer', ['notnull' => true]);

$this->dropAndCreateTable($table);
}

protected function tearDown(): void
{
$this->dropTableIfExists(self::TABLE_NAME);
}

public function testSuccessfulRowCountFromAffectedRows(): void
{
$mysqliStmt = $this->nativeConnection
->prepare(sprintf('INSERT INTO %s VALUES (7);', self::TABLE_NAME));
$mysqliStmt->execute();

self::assertSame(1, $mysqliStmt->affected_rows);
self::assertSame(1, (new Result($mysqliStmt))->rowCount());
}

public function testFailingRowCountFromAffectedRows(): void
{
$mysqliStmt = $this->nativeConnection
->prepare(sprintf('INSERT INTO %s VALUES (NULL);', self::TABLE_NAME));

$mysqliDriver = new mysqli_driver();

$mysqliReportMode = $mysqliDriver->report_mode;

// Set MySQL's driver report mode to `MYSQLI_REPORT_OFF` in order to avoid exception on errors.
$mysqliDriver->report_mode = MYSQLI_REPORT_OFF;

$mysqliStmt->execute();

self::assertSame(-1, $mysqliStmt->affected_rows);
self::assertSame(-1, (new Result($mysqliStmt))->rowCount());

// Restore default configuration.
$mysqliDriver->report_mode = $mysqliReportMode;

$error = null;

try {
$mysqliStmt->execute();
} catch (mysqli_sql_exception $error) {
// no-op.
}

self::assertInstanceOf(mysqli_sql_exception::class, $error);

$this->expectException(mysqli_sql_exception::class);
$this->expectExceptionMessage('Column \'my_col_1\' cannot be null');

new Result($mysqliStmt);
}
}

0 comments on commit bad8621

Please sign in to comment.