SchemaTest.php

Same filename in this branch
  1. 9 core/modules/mysql/tests/src/Kernel/mysql/SchemaTest.php
  2. 9 core/modules/pgsql/tests/src/Kernel/pgsql/SchemaTest.php
  3. 9 core/tests/Drupal/KernelTests/Core/Database/SchemaTest.php
Same filename in other branches
  1. 8.9.x core/tests/Drupal/KernelTests/Core/Database/SchemaTest.php
  2. 10 core/modules/sqlite/tests/src/Kernel/sqlite/SchemaTest.php
  3. 10 core/modules/mysql/tests/src/Kernel/mysql/SchemaTest.php
  4. 10 core/modules/pgsql/tests/src/Unit/SchemaTest.php
  5. 10 core/modules/pgsql/tests/src/Kernel/pgsql/SchemaTest.php
  6. 11.x core/modules/sqlite/tests/src/Kernel/sqlite/SchemaTest.php
  7. 11.x core/modules/mysql/tests/src/Kernel/mysql/SchemaTest.php
  8. 11.x core/modules/pgsql/tests/src/Unit/SchemaTest.php
  9. 11.x core/modules/pgsql/tests/src/Kernel/pgsql/SchemaTest.php

Namespace

Drupal\Tests\pgsql\Unit

File

core/modules/pgsql/tests/src/Unit/SchemaTest.php

View source
<?php

namespace Drupal\Tests\pgsql\Unit;

use Drupal\pgsql\Driver\Database\pgsql\Schema;
use Drupal\Tests\UnitTestCase;
// cSpell:ignore conname

/**
 * @coversDefaultClass \Drupal\pgsql\Driver\Database\pgsql\Schema
 * @group Database
 */
class SchemaTest extends UnitTestCase {
    
    /**
     * The PostgreSql DB connection.
     *
     * @var \PHPUnit\Framework\MockObject\MockObject|\Drupal\pgsql\Driver\Database\pgsql\Connection
     */
    protected $connection;
    
    /**
     * {@inheritdoc}
     */
    protected function setUp() : void {
        parent::setUp();
        $this->connection = $this->getMockBuilder('\\Drupal\\pgsql\\Driver\\Database\\pgsql\\Connection')
            ->disableOriginalConstructor()
            ->getMock();
    }
    
    /**
     * Tests whether the actual constraint name is correctly computed.
     *
     * @param string $table_name
     *   The table name the constrained column belongs to.
     * @param string $name
     *   The constraint name.
     * @param string $expected
     *   The expected computed constraint name.
     *
     * @covers ::constraintExists
     * @dataProvider providerComputedConstraintName
     */
    public function testComputedConstraintName($table_name, $name, $expected) {
        $max_identifier_length = 63;
        $schema = new Schema($this->connection);
        $statement = $this->createMock('\\Drupal\\Core\\Database\\StatementInterface');
        $statement->expects($this->any())
            ->method('fetchField')
            ->willReturn($max_identifier_length);
        $this->connection
            ->expects($this->exactly(2))
            ->method('query')
            ->withConsecutive([
            $this->anything(),
        ], [
            "SELECT 1 FROM pg_constraint WHERE conname = '{$expected}'",
        ])
            ->willReturnOnConsecutiveCalls($statement, $this->createMock('\\Drupal\\Core\\Database\\StatementInterface'));
        $schema->constraintExists($table_name, $name);
    }
    
    /**
     * Data provider for ::testComputedConstraintName().
     */
    public function providerComputedConstraintName() {
        return [
            [
                'user_field_data',
                'pkey',
                'user_field_data____pkey',
            ],
            [
                'user_field_data',
                'name__key',
                'user_field_data__name__key',
            ],
            [
                'user_field_data',
                'a_very_very_very_very_super_long_field_name__key',
                'drupal_WW_a8TlbZ3UQi20UTtRlJFaIeSa6FEtQS5h4NRA3UeU_key',
            ],
        ];
    }

}

Classes

Title Deprecated Summary
SchemaTest @coversDefaultClass \Drupal\pgsql\Driver\Database\pgsql\Schema @group Database

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