Issue #3069046 by mikelutz, init90, voleger, imalabya, andypost, catch, Berdir: Properly manage newly required parameter of FileUsageBase::__construct()
							parent
							
								
									771adc4826
								
							
						
					
					
						commit
						ae58cf0b05
					
				| 
						 | 
				
			
			@ -1,6 +1,6 @@
 | 
			
		|||
services:
 | 
			
		||||
  file.usage:
 | 
			
		||||
    class: Drupal\file\FileUsage\DatabaseFileUsageBackend
 | 
			
		||||
    arguments: ['@database', 'file_usage', '@config.factory']
 | 
			
		||||
    arguments: ['@config.factory', '@database', 'file_usage']
 | 
			
		||||
    tags:
 | 
			
		||||
      - { name: backend_overridable }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -28,18 +28,39 @@ class DatabaseFileUsageBackend extends FileUsageBase {
 | 
			
		|||
  /**
 | 
			
		||||
   * Construct the DatabaseFileUsageBackend.
 | 
			
		||||
   *
 | 
			
		||||
   * @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
 | 
			
		||||
   *   The config factory.
 | 
			
		||||
   * @param \Drupal\Core\Database\Connection $connection
 | 
			
		||||
   *   The database connection which will be used to store the file usage
 | 
			
		||||
   *   information.
 | 
			
		||||
   * @param string $table
 | 
			
		||||
   *   (optional) The table to store file usage info. Defaults to 'file_usage'.
 | 
			
		||||
   * @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
 | 
			
		||||
   *   (optional) The config factory.
 | 
			
		||||
   *
 | 
			
		||||
   * @todo Properly type-hint the constructor arguments in
 | 
			
		||||
   *   https://www.drupal.org/project/drupal/issues/3070114 when the
 | 
			
		||||
   *   drupal:9.0.x branch is opened.
 | 
			
		||||
   */
 | 
			
		||||
  public function __construct(Connection $connection, $table = 'file_usage', ConfigFactoryInterface $config_factory = NULL) {
 | 
			
		||||
  // @codingStandardsIgnoreLine
 | 
			
		||||
  public function __construct($config_factory, $connection = NULL, $table = 'file_usage') {
 | 
			
		||||
 | 
			
		||||
    // @todo Remove below conditional when the drupal:9.0.x branch is opened.
 | 
			
		||||
    // @see https://www.drupal.org/project/drupal/issues/3070114
 | 
			
		||||
    if (!$config_factory instanceof ConfigFactoryInterface) {
 | 
			
		||||
      @trigger_error('Passing the database connection as the first argument to ' . __METHOD__ . ' is deprecated in drupal:8.8.0 and will throw a fatal error in drupal:9.0.0. Pass the config factory first. See https://www.drupal.org/node/3070148', E_USER_DEPRECATED);
 | 
			
		||||
      if (!$config_factory instanceof Connection) {
 | 
			
		||||
        throw new \InvalidArgumentException("The first argument to " . __METHOD__ . " should be an instance of \Drupal\Core\Config\ConfigFactoryInterface, " . gettype($config_factory) . " given.");
 | 
			
		||||
      }
 | 
			
		||||
      list($connection, $table, $config_factory) = array_pad(func_get_args(), 3, NULL);
 | 
			
		||||
      if (NULL === $table) {
 | 
			
		||||
        $table = 'file_usage';
 | 
			
		||||
      }
 | 
			
		||||
      if (!$config_factory instanceof ConfigFactoryInterface) {
 | 
			
		||||
        $config_factory = \Drupal::configFactory();
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    parent::__construct($config_factory);
 | 
			
		||||
    $this->connection = $connection;
 | 
			
		||||
 | 
			
		||||
    $this->tableName = $table;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -21,14 +21,22 @@ abstract class FileUsageBase implements FileUsageInterface {
 | 
			
		|||
   * Creates a FileUsageBase object.
 | 
			
		||||
   *
 | 
			
		||||
   * @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
 | 
			
		||||
   *   (optional) The config factory. Defaults to NULL and will use
 | 
			
		||||
   *   \Drupal::configFactory() instead.
 | 
			
		||||
   *   The config factory. This parameter is required as of drupal:8.4.0 and
 | 
			
		||||
   *   trigger a fatal error if not passed in drupal:9.0.0.
 | 
			
		||||
   *
 | 
			
		||||
   * @deprecated The $config_factory parameter will become required in Drupal
 | 
			
		||||
   *   9.0.0.
 | 
			
		||||
   * @todo Update the docblock and make $config_factory required in
 | 
			
		||||
   *   https://www.drupal.org/project/drupal/issues/3070114 when the
 | 
			
		||||
   *   drupal:9.0.x branch is opened.
 | 
			
		||||
   */
 | 
			
		||||
  public function __construct(ConfigFactoryInterface $config_factory = NULL) {
 | 
			
		||||
    $this->configFactory = $config_factory ?: \Drupal::configFactory();
 | 
			
		||||
    // @todo Remove below conditional when the drupal:9.0.x branch is opened.
 | 
			
		||||
    // @see https://www.drupal.org/project/drupal/issues/3070114
 | 
			
		||||
    if (empty($config_factory)) {
 | 
			
		||||
      @trigger_error('Not passing the $config_factory parameter to ' . __METHOD__ . ' is deprecated in drupal:8.4.0 and will trigger a fatal error in drupal:9.0.0. See https://www.drupal.org/project/drupal/issues/2801777', E_USER_DEPRECATED);
 | 
			
		||||
      $config_factory = \Drupal::configFactory();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    $this->configFactory = $config_factory;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,107 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
namespace Drupal\Tests\file\Unit;
 | 
			
		||||
 | 
			
		||||
use Drupal\Core\Config\ConfigFactoryInterface;
 | 
			
		||||
use Drupal\Core\Database\Connection;
 | 
			
		||||
use Drupal\Core\DependencyInjection\ContainerBuilder;
 | 
			
		||||
use Drupal\file\FileInterface;
 | 
			
		||||
use Drupal\file\FileUsage\DatabaseFileUsageBackend;
 | 
			
		||||
use Drupal\file\FileUsage\FileUsageBase;
 | 
			
		||||
use PHPUnit\Framework\TestCase;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Provides unit tests for file module deprecation errors.
 | 
			
		||||
 *
 | 
			
		||||
 * @group file
 | 
			
		||||
 * @group legacy
 | 
			
		||||
 */
 | 
			
		||||
class LegacyFileTest extends TestCase {
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * A mocked ConfigFactoryInterface.
 | 
			
		||||
   *
 | 
			
		||||
   * @var \Drupal\Core\Config\ConfigFactoryInterface
 | 
			
		||||
   */
 | 
			
		||||
  protected $configFactory;
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * {@inheritdoc}
 | 
			
		||||
   */
 | 
			
		||||
  public function setUp() {
 | 
			
		||||
    parent::setUp();
 | 
			
		||||
    $this->configFactory = $this->prophesize(ConfigFactoryInterface::class)->reveal();
 | 
			
		||||
    $container = new ContainerBuilder();
 | 
			
		||||
    $container->set('config.factory', $this->configFactory);
 | 
			
		||||
    \Drupal::setContainer($container);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * Tests passing legacy arguments to FileUsageBase::__construct().
 | 
			
		||||
   *
 | 
			
		||||
   * @expectedDeprecation Not passing the $config_factory parameter to Drupal\file\FileUsage\FileUsageBase::__construct is deprecated in drupal:8.4.0 and will trigger a fatal error in drupal:9.0.0. See https://www.drupal.org/project/drupal/issues/2801777
 | 
			
		||||
   *
 | 
			
		||||
   * @throws \ReflectionException
 | 
			
		||||
   */
 | 
			
		||||
  public function testFileUsageBaseConstruct() {
 | 
			
		||||
    $test_file_usage = new TestFileUsage();
 | 
			
		||||
    $reflection = new \ReflectionObject($test_file_usage);
 | 
			
		||||
    $config = $reflection->getProperty('configFactory');
 | 
			
		||||
    $config->setAccessible(TRUE);
 | 
			
		||||
    $this->assertSame($this->configFactory, $config->getValue($test_file_usage));
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * Tests passing legacy arguments to DatabaseFileUsageBackend::__construct().
 | 
			
		||||
   *
 | 
			
		||||
   * @expectedDeprecation Passing the database connection as the first argument to Drupal\file\FileUsage\DatabaseFileUsageBackend::__construct is deprecated in drupal:8.8.0 and will throw a fatal error in drupal:9.0.0. Pass the config factory first. See https://www.drupal.org/node/3070148
 | 
			
		||||
   *
 | 
			
		||||
   * @throws \ReflectionException
 | 
			
		||||
   */
 | 
			
		||||
  public function testDatabaseFileUsageBackendConstruct() {
 | 
			
		||||
    $connection = $this->prophesize(Connection::class)->reveal();
 | 
			
		||||
    $database_file_usage = new DatabaseFileUsageBackend($connection);
 | 
			
		||||
    $reflection = new \ReflectionObject($database_file_usage);
 | 
			
		||||
    $reflection_config = $reflection->getProperty('configFactory');
 | 
			
		||||
    $reflection_config->setAccessible(TRUE);
 | 
			
		||||
    $reflection_connection = $reflection->getProperty('connection');
 | 
			
		||||
    $reflection_connection->setAccessible(TRUE);
 | 
			
		||||
    $reflection_table_name = $reflection->getProperty('tableName');
 | 
			
		||||
    $reflection_table_name->setAccessible(TRUE);
 | 
			
		||||
    $this->assertSame($this->configFactory, $reflection_config->getValue($database_file_usage));
 | 
			
		||||
    $this->assertSame($connection, $reflection_connection->getValue($database_file_usage));
 | 
			
		||||
    $this->assertSame('file_usage', $reflection_table_name->getValue($database_file_usage));
 | 
			
		||||
 | 
			
		||||
    $database_file_usage_test_table = new DatabaseFileUsageBackend($connection, 'test_table');
 | 
			
		||||
    $this->assertSame('test_table', $reflection_table_name->getValue($database_file_usage_test_table));
 | 
			
		||||
 | 
			
		||||
    $this->expectException(\InvalidArgumentException::class);
 | 
			
		||||
    $database_file_usage_exception = new DatabaseFileUsageBackend('Invalid Argument');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Provides a pass through to the abstract FileUsageBase() constructor.
 | 
			
		||||
 */
 | 
			
		||||
class TestFileUsage extends FileUsageBase {
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * {@inheritdoc}
 | 
			
		||||
   */
 | 
			
		||||
  public function add(FileInterface $file, $module, $type, $id, $count = 1) {
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * {@inheritdoc}
 | 
			
		||||
   */
 | 
			
		||||
  public function delete(FileInterface $file, $module, $type = NULL, $id = NULL, $count = 1) {
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  /**
 | 
			
		||||
   * {@inheritdoc}
 | 
			
		||||
   */
 | 
			
		||||
  public function listUsage(FileInterface $file) {
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
		Loading…
	
		Reference in New Issue