ServiceDestructionTest.php

Same filename and directory in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/DrupalKernel/ServiceDestructionTest.php
  2. 8.9.x core/tests/Drupal/KernelTests/Core/DrupalKernel/ServiceDestructionTest.php
  3. 10 core/tests/Drupal/KernelTests/Core/DrupalKernel/ServiceDestructionTest.php

Namespace

Drupal\KernelTests\Core\DrupalKernel

File

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 Symfony\Component\HttpFoundation\Response;

/**
 * Tests that services are correctly destructed.
 *
 * @group DrupalKernel
 */
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'));
  }
  
  /**
   * @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.