60 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
declare(strict_types=1);
 | 
						|
 | 
						|
namespace Drupal\Tests;
 | 
						|
 | 
						|
use Drupal\Core\Entity\EntityInterface;
 | 
						|
 | 
						|
/**
 | 
						|
 * Provides helper methods for working with entities in tests.
 | 
						|
 *
 | 
						|
 * Expects the $entityTypeManager class property.
 | 
						|
 */
 | 
						|
trait EntityTrait {
 | 
						|
 | 
						|
  /**
 | 
						|
   * A list of entity IDs generated by self::generateRandomEntityId().
 | 
						|
   *
 | 
						|
   * @var array
 | 
						|
   */
 | 
						|
  protected array $generatedIds = [];
 | 
						|
 | 
						|
  /**
 | 
						|
   * Reloads the given entity from the storage and returns it.
 | 
						|
   *
 | 
						|
   * @param \Drupal\Core\Entity\EntityInterface $entity
 | 
						|
   *   The entity to be reloaded.
 | 
						|
   *
 | 
						|
   * @return \Drupal\Core\Entity\EntityInterface
 | 
						|
   *   The reloaded entity.
 | 
						|
   */
 | 
						|
  protected function reloadEntity(EntityInterface $entity): EntityInterface {
 | 
						|
    $controller = $this->entityTypeManager->getStorage($entity->getEntityTypeId());
 | 
						|
    $controller->resetCache([$entity->id()]);
 | 
						|
    return $controller->load($entity->id());
 | 
						|
  }
 | 
						|
 | 
						|
  /**
 | 
						|
   * Generates a random ID avoiding collisions.
 | 
						|
   *
 | 
						|
   * @param bool $string
 | 
						|
   *   (optional) Whether the id should have string type. Defaults to FALSE.
 | 
						|
   *
 | 
						|
   * @return int|string
 | 
						|
   *   The entity identifier.
 | 
						|
   */
 | 
						|
  protected function generateRandomEntityId(bool $string = FALSE): int|string {
 | 
						|
    srand(time());
 | 
						|
    do {
 | 
						|
      // 0x7FFFFFFF is the maximum allowed value for integers that works for all
 | 
						|
      // Drupal supported databases and is known to work for other databases
 | 
						|
      // like SQL Server 2014 and Oracle 10 too.
 | 
						|
      $id = $string ? $this->randomMachineName() : mt_rand(1, 0x7FFFFFFF);
 | 
						|
    } while (isset($this->generatedIds[$id]));
 | 
						|
    $this->generatedIds[$id] = $id;
 | 
						|
    return $id;
 | 
						|
  }
 | 
						|
 | 
						|
}
 |