public function IntegrationTest::testLinkTracking in Entity Usage 8.2
Same name and namespace in other branches
- 8.4 tests/src/FunctionalJavascript/IntegrationTest.php \Drupal\Tests\entity_usage\FunctionalJavascript\IntegrationTest::testLinkTracking()
- 8 tests/src/FunctionalJavascript/IntegrationTest.php \Drupal\Tests\entity_usage\FunctionalJavascript\IntegrationTest::testLinkTracking()
- 8.3 tests/src/FunctionalJavascript/IntegrationTest.php \Drupal\Tests\entity_usage\FunctionalJavascript\IntegrationTest::testLinkTracking()
Tests the tracking of nodes in link fields.
File
- tests/
src/ FunctionalJavascript/ IntegrationTest.php, line 327
Class
- IntegrationTest
- Basic functional tests for the usage tracking.
Namespace
Drupal\Tests\entity_usage\FunctionalJavascriptCode
public function testLinkTracking() {
$session = $this
->getSession();
$page = $session
->getPage();
$assert_session = $this
->assertSession();
/** @var \Drupal\entity_usage\EntityUsage $usage_service */
$usage_service = \Drupal::service('entity_usage.usage');
// Add a link field to our test content type.
$field_storage = FieldStorageConfig::create([
'field_name' => 'field_link1',
'entity_type' => 'node',
'type' => 'link',
'cardinality' => FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED,
'settings' => [],
]);
$field_storage
->save();
$field = FieldConfig::create([
'field_storage' => $field_storage,
'bundle' => 'eu_test_ct',
'settings' => [
'title' => DRUPAL_OPTIONAL,
'link_type' => LinkItemInterface::LINK_GENERIC,
],
]);
$field
->save();
\Drupal::service('entity_display.repository')
->getFormDisplay('node', 'eu_test_ct', 'default')
->setComponent('field_link1', [
'type' => 'link_default',
])
->save();
\Drupal::service('entity_display.repository')
->getViewDisplay('node', 'eu_test_ct', 'default')
->setComponent('field_link1', [
'type' => 'link',
])
->save();
// Create Node 1.
$this
->drupalGet('/node/add/eu_test_ct');
$page
->fillField('title[0][value]', 'Node 1');
$page
->pressButton('Save');
$session
->wait(500);
$this
->saveHtmlOutput();
$assert_session
->pageTextContains('eu_test_ct Node 1 has been created.');
/** @var \Drupal\node\NodeInterface $node1 */
$node1 = $this
->getLastEntityOfType('node', TRUE);
// Create Node 2, referencing Node 1.
$this
->drupalGet('/node/add/eu_test_ct');
$page
->fillField('title[0][value]', 'Node 2');
$page
->fillField('field_link1[0][uri]', "Node 1 ({$node1->id()})");
$page
->fillField('field_link1[0][title]', "Linked text");
$page
->pressButton('Save');
$session
->wait(500);
$this
->saveHtmlOutput();
$assert_session
->pageTextContains('eu_test_ct Node 2 has been created.');
$node2 = $this
->getLastEntityOfType('node', TRUE);
// Check that the usage of Node 1 points to Node 2.
$usage = $usage_service
->listSources($node1);
$expected = [
'node' => [
$node2
->id() => [
0 => [
'source_langcode' => 'en',
'source_vid' => $node2
->getRevisionId(),
'method' => 'link',
'field_name' => 'field_link1',
'count' => 1,
],
],
],
];
$this
->assertEquals($expected, $usage);
// Edit Node 2, remove reference.
$this
->drupalGet("/node/{$node2->id()}/edit");
$page
->fillField('field_link1[0][uri]', '');
$page
->fillField('field_link1[0][title]', '');
$page
->pressButton('Save');
$session
->wait(500);
$this
->saveHtmlOutput();
$assert_session
->pageTextContains('eu_test_ct Node 2 has been updated.');
// Verify the usage was released.
$usage = $usage_service
->listSources($node1);
$this
->assertEquals([], $usage);
// Reference Node 1 again, now using the node path instead of label.
$this
->drupalGet("/node/{$node2->id()}/edit");
$page
->fillField('field_link1[0][uri]', "entity:node/{$node1->id()}");
$page
->fillField('field_link1[0][title]', "Linked text");
$page
->pressButton('Save');
$this
->saveHtmlOutput();
$assert_session
->pageTextContains('eu_test_ct Node 2 has been updated.');
// Usage now should be there.
$usage = $usage_service
->listSources($node1);
$expected = [
'node' => [
$node2
->id() => [
0 => [
'source_langcode' => 'en',
'source_vid' => $node2
->getRevisionId(),
'method' => 'link',
'field_name' => 'field_link1',
'count' => 1,
],
],
],
];
$this
->assertEquals($expected, $usage);
// Delete the source and usage should be released.
$node2
->delete();
$usage = $usage_service
->listSources($node1);
$this
->assertEquals([], $usage);
}