SchemaInspector.php

Same filename in other branches
  1. 9 core/tests/Drupal/TestTools/Extension/SchemaInspector.php
  2. 10 core/tests/Drupal/TestTools/Extension/SchemaInspector.php

Namespace

Drupal\TestTools\Extension

File

core/tests/Drupal/TestTools/Extension/SchemaInspector.php

View source
<?php

declare (strict_types=1);
namespace Drupal\TestTools\Extension;

use Drupal\Core\Extension\ModuleHandlerInterface;

/**
 * Provides methods to access modules' schema.
 */
class SchemaInspector {
    
    /**
     * Returns the module's schema specification.
     *
     * This function can be used to retrieve a schema specification provided by
     * hook_schema(), so it allows you to derive your tables from existing
     * specifications.
     *
     * @param \Drupal\Core\Extension\ModuleHandlerInterface $handler
     *   The module handler to use for calling schema hook.
     * @param string $module
     *   The module to which the table belongs.
     *
     * @return array
     *   An array of schema definition provided by hook_schema().
     *
     * @see \hook_schema()
     */
    public static function getTablesSpecification(ModuleHandlerInterface $handler, string $module) : array {
        if ($handler->loadInclude($module, 'install')) {
            return $handler->invoke($module, 'schema') ?? [];
        }
        return [];
    }

}

Classes

Title Deprecated Summary
SchemaInspector Provides methods to access modules' schema.

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