You are here

public function MoveTest::testNormal in Drupal 9

Same name and namespace in other branches
  1. 8 core/modules/file/tests/src/Kernel/MoveTest.php \Drupal\Tests\file\Kernel\MoveTest::testNormal()
  2. 10 core/modules/file/tests/src/Kernel/MoveTest.php \Drupal\Tests\file\Kernel\MoveTest::testNormal()

Move a normal file.

File

core/modules/file/tests/src/Kernel/MoveTest.php, line 19

Class

MoveTest
Tests the file move function.

Namespace

Drupal\Tests\file\Kernel

Code

public function testNormal() {
  $contents = $this
    ->randomMachineName(10);
  $source = $this
    ->createFile(NULL, $contents);
  $desired_filepath = 'public://' . $this
    ->randomMachineName();

  // Clone the object so we don't have to worry about the function changing
  // our reference copy.
  $result = file_move(clone $source, $desired_filepath, FileSystemInterface::EXISTS_ERROR);

  // Check the return status and that the contents changed.
  $this
    ->assertNotFalse($result, 'File moved successfully.');
  $this
    ->assertFileDoesNotExist($source
    ->getFileUri());
  $this
    ->assertEquals($contents, file_get_contents($result
    ->getFileUri()), 'Contents of file correctly written.');

  // Check that the correct hooks were called.
  $this
    ->assertFileHooksCalled([
    'move',
    'load',
    'update',
  ]);

  // Make sure we got the same file back.
  $this
    ->assertEquals($source
    ->id(), $result
    ->id(), new FormattableMarkup("Source file id's' %fid is unchanged after move.", [
    '%fid' => $source
      ->id(),
  ]));

  // Reload the file from the database and check that the changes were
  // actually saved.
  $loaded_file = File::load($result
    ->id());
  $this
    ->assertNotEmpty($loaded_file, 'File can be loaded from the database.');
  $this
    ->assertFileUnchanged($result, $loaded_file);
}