ServiceDestructionTest.php
Namespace
Drupal\KernelTests\Core\DrupalKernelFile
- 
              core/tests/ Drupal/ KernelTests/ Core/ DrupalKernel/ ServiceDestructionTest.php 
View source
<?php
declare (strict_types=1);
namespace Drupal\KernelTests\Core\DrupalKernel;
use Drupal\KernelTests\KernelTestBase;
use PHPUnit\Framework\Attributes\Group;
use PHPUnit\Framework\Attributes\RunTestsInSeparateProcesses;
use Symfony\Component\HttpFoundation\Response;
/**
 * Tests that services are correctly destructed.
 */
class ServiceDestructionTest extends KernelTestBase {
  
  /**
   * Verifies that services are destructed when used.
   */
  public function testDestructionUsed() : void {
    // Enable the test module to add it to the container.
    $this->enableModules([
      'service_provider_test',
    ]);
    $request = $this->container
      ->get('request_stack')
      ->getCurrentRequest();
    $kernel = $this->container
      ->get('kernel');
    $kernel->preHandle($request);
    // The service has not been destructed yet.
    $this->assertNull(\Drupal::state()->get('service_provider_test.destructed'));
    // Call the class and then terminate the kernel.
    $this->container
      ->get('service_provider_test_class');
    $response = new Response();
    $kernel->terminate($request, $response);
    $this->assertTrue(\Drupal::state()->get('service_provider_test.destructed'));
  }
  
  /**
   * Verifies that services are not unnecessarily destructed when not used.
   */
  public function testDestructionUnused() : void {
    // Enable the test module to add it to the container.
    $this->enableModules([
      'service_provider_test',
    ]);
    $request = $this->container
      ->get('request_stack')
      ->getCurrentRequest();
    $kernel = $this->container
      ->get('kernel');
    $kernel->preHandle($request);
    // The service has not been destructed yet.
    $this->assertNull(\Drupal::state()->get('service_provider_test.destructed'));
    // Terminate the kernel. The test class has not been called, so it should
    // not be destructed.
    $response = new Response();
    $kernel->terminate($request, $response);
    $this->assertNull(\Drupal::state()->get('service_provider_test.destructed'));
  }
  
  /**
   * Tests destructable services order.
   *
   * @legacy-covers \Drupal\Core\DependencyInjection\Compiler\RegisterServicesForDestructionPass::process
   */
  public function testDestructableServicesOrder() : void {
    // Destructable services before the module is enabled.
    $core_services = $this->container
      ->getParameter('kernel.destructable_services');
    $this->enableModules([
      'service_provider_test',
    ]);
    $services = $this->container
      ->getParameter('kernel.destructable_services');
    // Remove the core registered services for clarity.
    $testable_services = array_values(array_diff($services, $core_services));
    $this->assertSame([
      // Priority 100.
'service_provider_test_class_5',
      // Priority 50.
'service_provider_test_class_1',
      // The following two services are both with priority 0 and their order is
      // determined by the order they were registered.
'service_provider_test_class',
      'service_provider_test_class_3',
      // Priority -10.
'service_provider_test_class_2',
      // Priority -50.
'service_provider_test_class_6',
      // Priority -100.
'service_provider_test_class_4',
    ], $testable_services);
  }
}Classes
| Title | Deprecated | Summary | 
|---|---|---|
| ServiceDestructionTest | Tests that services are correctly destructed. | 
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.
