function ContextPluginTest::testContext

Same name and namespace in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/Plugin/ContextPluginTest.php \Drupal\KernelTests\Core\Plugin\ContextPluginTest::testContext()
  2. 8.9.x core/tests/Drupal/KernelTests/Core/Plugin/ContextPluginTest.php \Drupal\KernelTests\Core\Plugin\ContextPluginTest::testContext()
  3. 10 core/tests/Drupal/KernelTests/Core/Plugin/ContextPluginTest.php \Drupal\KernelTests\Core\Plugin\ContextPluginTest::testContext()

Tests basic context definition and value getters and setters.

File

core/tests/Drupal/KernelTests/Core/Plugin/ContextPluginTest.php, line 37

Class

ContextPluginTest
Tests that contexts are properly set and working within plugins.

Namespace

Drupal\KernelTests\Core\Plugin

Code

public function testContext() : void {
  $this->installEntitySchema('user');
  $this->installEntitySchema('node');
  $type = NodeType::create([
    'type' => 'page',
    'name' => 'Page',
  ]);
  $type->save();
  $name = $this->randomMachineName();
  $manager = new MockBlockManager();
  $plugin = $manager->createInstance('user_name');
  // Create a node, add it as context, catch the exception.
  $node = Node::create([
    'type' => 'page',
    'title' => $name,
  ]);
  // Try to get context that is missing its definition.
  try {
    $plugin->getContextDefinition('not_exists');
    $this->fail('The user context should not yet be set.');
  } catch (ContextException $e) {
    $this->assertEquals('The not_exists context is not a valid context.', $e->getMessage());
  }
  // Test the getContextDefinitions() method.
  $user_context_definition = EntityContextDefinition::fromEntityTypeId('user')->setLabel('User');
  $this->assertEquals($plugin->getContextDefinitions()['user']
    ->getLabel(), $user_context_definition->getLabel());
  // Test the getContextDefinition() method for a valid context.
  $this->assertEquals($plugin->getContextDefinition('user')
    ->getLabel(), $user_context_definition->getLabel());
  // Try to get a context with valid definition.
  $this->assertNotNull($plugin->getContext('user'), 'Succeeded to get a context with a valid definition.');
  // Try to get a value of a valid context, while this value has not been set.
  try {
    $plugin->getContextValue('user');
  } catch (ContextException $e) {
    $this->assertSame("The 'entity:user' context is required and not present.", $e->getMessage(), 'Requesting a non-set value of a required context should throw a context exception.');
  }
  // Try to pass the wrong class type as a context value.
  $plugin->setContextValue('user', $node);
  $violations = $plugin->validateContexts();
  $this->assertNotEmpty($violations, 'The provided context value does not pass validation.');
  // Set an appropriate context value and check to make sure its methods work
  // as expected.
  $user = User::create([
    'name' => $name,
  ]);
  $plugin->setContextValue('user', $user);
  $this->assertEquals($user->getAccountName(), $plugin->getContextValue('user')
    ->getAccountName());
  $this->assertEquals($user->label(), $plugin->getTitle());
  // Test Optional context handling.
  $plugin = $manager->createInstance('user_name_optional');
  $this->assertNull($plugin->getContextValue('user'), 'Requesting a non-set value of a valid context should return NULL.');
  // Test Complex compound context handling.
  $complex_plugin = $manager->createInstance('complex_context');
  $complex_plugin->setContextValue('user', $user);
  // With only the user context set, try to get the context values.
  $values = $complex_plugin->getContextValues();
  $this->assertNull($values['node'], 'The node context is not yet set.');
  $this->assertNotNull($values['user'], 'The user context is set');
  $complex_plugin->setContextValue('node', $node);
  $context_wrappers = $complex_plugin->getContexts();
  // Make sure what came out of the wrappers is good.
  $this->assertEquals($user->label(), $context_wrappers['user']->getContextValue()
    ->label());
  $this->assertEquals($node->label(), $context_wrappers['node']->getContextValue()
    ->label());
  // Make sure what comes out of the context values is good.
  $contexts = $complex_plugin->getContextValues();
  $this->assertEquals($user->label(), $contexts['user']->label());
  $this->assertEquals($node->label(), $contexts['node']->label());
  // Test the title method for the complex context plugin.
  $this->assertEquals($user->label() . ' -- ' . $node->label(), $complex_plugin->getTitle());
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.