You are here

class SqlModeTest in Drupal 10

Same name and namespace in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/Database/SqlModeTest.php \Drupal\KernelTests\Core\Database\SqlModeTest

Tests compatibility of the MySQL driver with various sql_mode options.

@group Database

Hierarchy

Expanded class hierarchy of SqlModeTest

File

core/tests/Drupal/KernelTests/Core/Database/SqlModeTest.php, line 10

Namespace

Drupal\KernelTests\Core\Database
View source
class SqlModeTest extends DatabaseTestBase {

  /**
   * {@inheritdoc}
   */
  protected function setUp() : void {
    parent::setUp();
    if ($this->connection
      ->databaseType() !== 'mysql') {
      $this
        ->markTestSkipped("Skipping test since sql_mode is a MySQL-only feature.");
    }
  }

  /**
   * Tests quoting identifiers in queries.
   */
  public function testQuotingIdentifiers() {

    // Use SQL-reserved words for both the table and column names.
    $query = $this->connection
      ->query('SELECT [update] FROM {select}');
    $this
      ->assertEquals('Update value 1', $query
      ->fetchObject()->update);
    $this
      ->assertStringContainsString('SELECT `update` FROM `', $query
      ->getQueryString());
  }

  /**
   * {@inheritdoc}
   */
  protected function getDatabaseConnectionInfo() {
    $info = parent::getDatabaseConnectionInfo();

    // This runs during setUp(), so is not yet skipped for non MySQL databases.
    // We defer skipping the test to later in setUp(), so that that can be
    // based on databaseType() rather than 'driver', but here all we have to go
    // on is 'driver'.
    if ($info['default']['driver'] === 'mysql') {
      $info['default']['init_commands']['sql_mode'] = "SET sql_mode = ''";
    }
    return $info;
  }

}

Members