RegressionTest.php

Same filename and directory in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/Database/RegressionTest.php
  2. 8.9.x core/tests/Drupal/KernelTests/Core/Database/RegressionTest.php
  3. 11.x core/tests/Drupal/KernelTests/Core/Database/RegressionTest.php

Namespace

Drupal\KernelTests\Core\Database

File

core/tests/Drupal/KernelTests/Core/Database/RegressionTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\KernelTests\Core\Database;


/**
 * Regression tests cases for the database layer.
 *
 * @group Database
 */
class RegressionTest extends DatabaseTestBase {
  
  /**
   * {@inheritdoc}
   */
  protected static $modules = [
    'node',
    'user',
  ];
  
  /**
   * Ensures that non-ASCII UTF-8 data is stored in the database properly.
   */
  public function testRegression_310447() : void {
    // That's a 255 character UTF-8 string.
    $job = str_repeat("é", 255);
    $this->connection
      ->insert('test')
      ->fields([
      'name' => $this->randomMachineName(),
      'age' => 20,
      'job' => $job,
    ])
      ->execute();
    $from_database = $this->connection
      ->query('SELECT [job] FROM {test} WHERE [job] = :job', [
      ':job' => $job,
    ])
      ->fetchField();
    $this->assertSame($job, $from_database, 'The database handles UTF-8 characters cleanly.');
  }
  
  /**
   * Tests the Schema::tableExists() method.
   */
  public function testDBTableExists() : void {
    $this->assertTrue($this->connection
      ->schema()
      ->tableExists('test'), 'Returns true for existent table.');
    $this->assertFalse($this->connection
      ->schema()
      ->tableExists('no_such_table'), 'Returns false for nonexistent table.');
  }
  
  /**
   * Tests the \Drupal\Core\Database\Schema::fieldExists() method.
   */
  public function testDBFieldExists() : void {
    $schema = $this->connection
      ->schema();
    $this->assertTrue($schema->fieldExists('test', 'name'), 'Returns true for existent column.');
    $this->assertFalse($schema->fieldExists('test', 'no_such_column'), 'Returns false for nonexistent column.');
  }
  
  /**
   * Tests the Schema::indexExists() method.
   */
  public function testDBIndexExists() : void {
    $this->assertTrue($this->connection
      ->schema()
      ->indexExists('test', 'ages'), 'Returns true for existent index.');
    $this->assertFalse($this->connection
      ->schema()
      ->indexExists('test', 'no_such_index'), 'Returns false for nonexistent index.');
  }

}

Classes

Title Deprecated Summary
RegressionTest Regression tests cases for the database layer.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.