You are here

class MigrateExecutableMemoryExceededTest in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 core/modules/migrate/tests/src/Unit/MigrateExecutableMemoryExceededTest.php \Drupal\Tests\migrate\Unit\MigrateExecutableMemoryExceededTest

Tests the \Drupal\migrate\MigrateExecutable::memoryExceeded() method.

@group migrate

Hierarchy

Expanded class hierarchy of MigrateExecutableMemoryExceededTest

File

core/modules/migrate/tests/src/Unit/MigrateExecutableMemoryExceededTest.php, line 15
Contains \Drupal\Tests\migrate\Unit\MigrateExecutableMemoryExceededTest.

Namespace

Drupal\Tests\migrate\Unit
View source
class MigrateExecutableMemoryExceededTest extends MigrateTestCase {

  /**
   * The mocked migration entity.
   *
   * @var \Drupal\migrate\Entity\MigrationInterface|\PHPUnit_Framework_MockObject_MockObject
   */
  protected $migration;

  /**
   * The mocked migrate message.
   *
   * @var \Drupal\migrate\MigrateMessageInterface|\PHPUnit_Framework_MockObject_MockObject
   */
  protected $message;

  /**
   * The tested migrate executable.
   *
   * @var \Drupal\Tests\migrate\Unit\TestMigrateExecutable
   */
  protected $executable;

  /**
   * The migration configuration, initialized to set the ID to test.
   *
   * @var array
   */
  protected $migrationConfiguration = array(
    'id' => 'test',
  );

  /**
   * php.init memory_limit value.
   */
  protected $memoryLimit = 10000000;

  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    $this->migration = $this
      ->getMigration();
    $this->message = $this
      ->getMock('Drupal\\migrate\\MigrateMessageInterface');
    $this->executable = new TestMigrateExecutable($this->migration, $this->message);
    $this->executable
      ->setStringTranslation($this
      ->getStringTranslationStub());
  }

  /**
   * Runs the actual test.
   *
   * @param string $message
   *   The second message to assert.
   * @param bool $memory_exceeded
   *   Whether to test the memory exceeded case.
   * @param int $memory_usage_first
   *   (optional) The first memory usage value.
   * @param int $memory_usage_second
   *   (optional) The fake amount of memory usage reported after memory reclaim.
   * @param int $memory_limit
   *   (optional) The memory limit.
   */
  protected function runMemoryExceededTest($message, $memory_exceeded, $memory_usage_first = NULL, $memory_usage_second = NULL, $memory_limit = NULL) {
    $this->executable
      ->setMemoryLimit($memory_limit ?: $this->memoryLimit);
    $this->executable
      ->setMemoryUsage($memory_usage_first ?: $this->memoryLimit, $memory_usage_second ?: $this->memoryLimit);
    $this->executable
      ->setMemoryThreshold(0.85);
    if ($message) {
      $this->executable->message
        ->expects($this
        ->at(0))
        ->method('display')
        ->with($this
        ->stringContains('reclaiming memory'));
      $this->executable->message
        ->expects($this
        ->at(1))
        ->method('display')
        ->with($this
        ->stringContains($message));
    }
    else {
      $this->executable->message
        ->expects($this
        ->never())
        ->method($this
        ->anything());
    }
    $result = $this->executable
      ->memoryExceeded();
    $this
      ->assertEquals($memory_exceeded, $result);
  }

  /**
   * Tests memoryExceeded method when a new batch is needed.
   */
  public function testMemoryExceededNewBatch() {

    // First case try reset and then start new batch.
    $this
      ->runMemoryExceededTest('starting new batch', TRUE);
  }

  /**
   * Tests memoryExceeded method when enough is cleared.
   */
  public function testMemoryExceededClearedEnough() {
    $this
      ->runMemoryExceededTest('reclaimed enough', FALSE, $this->memoryLimit, $this->memoryLimit * 0.75);
  }

  /**
   * Tests memoryExceeded when memory usage is not exceeded.
   */
  public function testMemoryNotExceeded() {
    $this
      ->runMemoryExceededTest('', FALSE, floor($this->memoryLimit * 0.85) - 1);
  }

}

Members

Namesort descending Modifiers Type Description Overrides
MigrateExecutableMemoryExceededTest::$executable protected property The tested migrate executable.
MigrateExecutableMemoryExceededTest::$memoryLimit protected property php.init memory_limit value.
MigrateExecutableMemoryExceededTest::$message protected property The mocked migrate message.
MigrateExecutableMemoryExceededTest::$migration protected property The mocked migration entity.
MigrateExecutableMemoryExceededTest::$migrationConfiguration protected property The migration configuration, initialized to set the ID to test. Overrides MigrateTestCase::$migrationConfiguration
MigrateExecutableMemoryExceededTest::runMemoryExceededTest protected function Runs the actual test.
MigrateExecutableMemoryExceededTest::setUp protected function Overrides UnitTestCase::setUp
MigrateExecutableMemoryExceededTest::testMemoryExceededClearedEnough public function Tests memoryExceeded method when enough is cleared.
MigrateExecutableMemoryExceededTest::testMemoryExceededNewBatch public function Tests memoryExceeded method when a new batch is needed.
MigrateExecutableMemoryExceededTest::testMemoryNotExceeded public function Tests memoryExceeded when memory usage is not exceeded.
MigrateTestCase::$idMap protected property
MigrateTestCase::$migrationStatus protected property Local store for mocking setStatus()/getStatus().
MigrateTestCase::createSchemaFromRow protected function Generates a table schema from a row.
MigrateTestCase::getDatabase protected function Get an SQLite database connection object for use in tests.
MigrateTestCase::getMigration protected function Retrieve a mocked migration.
MigrateTestCase::getValue protected function 1
MigrateTestCase::queryResultTest public function Tests a query
MigrateTestCase::retrievalAssertHelper protected function Asserts tested values during test retrieval.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root.
UnitTestCase::assertArrayEquals protected function Asserts if two arrays are equal by sorting them first.
UnitTestCase::getBlockMockWithMachineName protected function Mocks a block with a block plugin.
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed in array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.