TestDatabaseTest.php

Same filename and directory in other branches
  1. 11.x core/tests/Drupal/Tests/Core/Test/TestDatabaseTest.php
  2. 10 core/tests/Drupal/Tests/Core/Test/TestDatabaseTest.php
  3. 9 core/tests/Drupal/Tests/Core/Test/TestDatabaseTest.php
  4. 8.9.x core/tests/Drupal/Tests/Core/Test/TestDatabaseTest.php

Namespace

Drupal\Tests\Core\Test

File

core/tests/Drupal/Tests/Core/Test/TestDatabaseTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\Tests\Core\Test;

use Drupal\Core\Test\TestDatabase;
use Drupal\Tests\UnitTestCase;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Group;

/**
 * Tests Drupal\Core\Test\TestDatabase.
 */
class TestDatabaseTest extends UnitTestCase {
  
  /**
   * Tests constructor exception.
   *
   * @legacy-covers ::__construct
   */
  public function testConstructorException() : void {
    $this->expectException(\InvalidArgumentException::class);
    $this->expectExceptionMessage("Invalid database prefix: blah1253");
    new TestDatabase('blah1253');
  }
  
  /**
   * Tests constructor.
   *
   * @legacy-covers ::__construct
   * @legacy-covers ::getDatabasePrefix
   * @legacy-covers ::getTestSitePath
   * @legacy-covers ::getPhpErrorLogPath
   */
  public function testConstructor($db_prefix, $expected_db_prefix, $expected_site_path) : void {
    $test_db = new TestDatabase($db_prefix);
    $this->assertEquals($expected_db_prefix, $test_db->getDatabasePrefix());
    $this->assertEquals($expected_site_path, $test_db->getTestSitePath());
    $this->assertEquals($expected_site_path . '/error.log', $test_db->getPhpErrorLogPath());
  }
  
  /**
   * Data provider for self::testConstructor()
   */
  public static function providerTestConstructor() : array {
    return [
      [
        'test1234',
        'test1234',
        'sites/simpletest/1234',
      ],
      [
        'test123456test234567',
        'test123456test234567',
        'sites/simpletest/234567',
      ],
    ];
  }
  
  /**
   * Verify that a test lock is generated if there is no provided prefix.
   *
   * @legacy-covers ::__construct
   * @legacy-covers ::getDatabasePrefix
   * @legacy-covers ::getTestSitePath
   * @legacy-covers ::getPhpErrorLogPath
   */
  public function testConstructorNullPrefix() : void {
    // We use a stub class here because we can't mock getTestLock() so that it's
    // available before the constructor is called.
    $test_db = new TestTestDatabase(NULL);
    $this->assertEquals('test23', $test_db->getDatabasePrefix());
    $this->assertEquals('sites/simpletest/23', $test_db->getTestSitePath());
    $this->assertEquals('sites/simpletest/23/error.log', $test_db->getPhpErrorLogPath());
  }

}

/**
 * Stub class supports TestDatabaseTest::testConstructorNullPrefix().
 */
class TestTestDatabase extends TestDatabase {
  protected function getTestLock(bool $create_lock = FALSE) : int {
    return 23;
  }

}

Classes

Title Deprecated Summary
TestDatabaseTest Tests Drupal\Core\Test\TestDatabase.
TestTestDatabase Stub class supports TestDatabaseTest::testConstructorNullPrefix().

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