public function FileTokenReplaceTest::testFileTokenReplacement in Drupal 8
Same name and namespace in other branches
- 9 core/modules/file/tests/src/Functional/FileTokenReplaceTest.php \Drupal\Tests\file\Functional\FileTokenReplaceTest::testFileTokenReplacement()
- 10 core/modules/file/tests/src/Functional/FileTokenReplaceTest.php \Drupal\Tests\file\Functional\FileTokenReplaceTest::testFileTokenReplacement()
Creates a file, then tests the tokens generated from it.
File
- core/
modules/ file/ tests/ src/ Functional/ FileTokenReplaceTest.php, line 26
Class
- FileTokenReplaceTest
- Generates text using placeholders for dummy content to check file token replacement.
Namespace
Drupal\Tests\file\FunctionalCode
public function testFileTokenReplacement() {
$node_storage = $this->container
->get('entity_type.manager')
->getStorage('node');
$token_service = \Drupal::token();
$language_interface = \Drupal::languageManager()
->getCurrentLanguage();
/** @var \Drupal\Core\Datetime\DateFormatterInterface $date_formatter */
$date_formatter = $this->container
->get('date.formatter');
// Create file field.
$type_name = 'article';
$field_name = 'field_' . strtolower($this
->randomMachineName());
$this
->createFileField($field_name, 'node', $type_name);
$test_file = $this
->getTestFile('text');
// Coping a file to test uploads with non-latin filenames.
$filename = \Drupal::service('file_system')
->dirname($test_file
->getFileUri()) . '/текстовый файл.txt';
$test_file = file_copy($test_file, $filename);
// Create a new node with the uploaded file.
$nid = $this
->uploadNodeFile($test_file, $field_name, $type_name);
// Load the node and the file.
$node_storage
->resetCache([
$nid,
]);
$node = $node_storage
->load($nid);
$file = File::load($node->{$field_name}->target_id);
// Generate and test sanitized tokens.
$tests = [];
$tests['[file:fid]'] = $file
->id();
$tests['[file:name]'] = Html::escape($file
->getFilename());
$tests['[file:path]'] = Html::escape($file
->getFileUri());
$tests['[file:mime]'] = Html::escape($file
->getMimeType());
$tests['[file:size]'] = format_size($file
->getSize());
$tests['[file:url]'] = Html::escape(file_create_url($file
->getFileUri()));
$tests['[file:created]'] = $date_formatter
->format($file
->getCreatedTime(), 'medium', '', NULL, $language_interface
->getId());
$tests['[file:created:short]'] = $date_formatter
->format($file
->getCreatedTime(), 'short', '', NULL, $language_interface
->getId());
$tests['[file:changed]'] = $date_formatter
->format($file
->getChangedTime(), 'medium', '', NULL, $language_interface
->getId());
$tests['[file:changed:short]'] = $date_formatter
->format($file
->getChangedTime(), 'short', '', NULL, $language_interface
->getId());
$tests['[file:owner]'] = Html::escape($this->adminUser
->getDisplayName());
$tests['[file:owner:uid]'] = $file
->getOwnerId();
$base_bubbleable_metadata = BubbleableMetadata::createFromObject($file);
$metadata_tests = [];
$metadata_tests['[file:fid]'] = $base_bubbleable_metadata;
$metadata_tests['[file:name]'] = $base_bubbleable_metadata;
$metadata_tests['[file:path]'] = $base_bubbleable_metadata;
$metadata_tests['[file:mime]'] = $base_bubbleable_metadata;
$metadata_tests['[file:size]'] = $base_bubbleable_metadata;
$bubbleable_metadata = clone $base_bubbleable_metadata;
$metadata_tests['[file:url]'] = $bubbleable_metadata
->addCacheContexts([
'url.site',
]);
$bubbleable_metadata = clone $base_bubbleable_metadata;
$metadata_tests['[file:created]'] = $bubbleable_metadata
->addCacheTags([
'rendered',
]);
$metadata_tests['[file:created:short]'] = $bubbleable_metadata;
$metadata_tests['[file:changed]'] = $bubbleable_metadata;
$metadata_tests['[file:changed:short]'] = $bubbleable_metadata;
$bubbleable_metadata = clone $base_bubbleable_metadata;
$metadata_tests['[file:owner]'] = $bubbleable_metadata
->addCacheTags([
'user:2',
]);
$metadata_tests['[file:owner:uid]'] = $bubbleable_metadata;
// Test to make sure that we generated something for each token.
$this
->assertNotContains(0, array_map('strlen', $tests), 'No empty tokens generated.');
foreach ($tests as $input => $expected) {
$bubbleable_metadata = new BubbleableMetadata();
$output = $token_service
->replace($input, [
'file' => $file,
], [
'langcode' => $language_interface
->getId(),
], $bubbleable_metadata);
$this
->assertEqual($output, $expected, new FormattableMarkup('Sanitized file token %token replaced.', [
'%token' => $input,
]));
$this
->assertEqual($bubbleable_metadata, $metadata_tests[$input]);
}
// Generate and test unsanitized tokens.
$tests['[file:name]'] = $file
->getFilename();
$tests['[file:path]'] = $file
->getFileUri();
$tests['[file:mime]'] = $file
->getMimeType();
$tests['[file:size]'] = format_size($file
->getSize());
foreach ($tests as $input => $expected) {
$output = $token_service
->replace($input, [
'file' => $file,
], [
'langcode' => $language_interface
->getId(),
'sanitize' => FALSE,
]);
$this
->assertEqual($output, $expected, new FormattableMarkup('Unsanitized file token %token replaced.', [
'%token' => $input,
]));
}
}