diff --git a/core/modules/taxonomy/src/Plugin/entity_reference/selection/TermSelection.php b/core/modules/taxonomy/src/Plugin/entity_reference/selection/TermSelection.php index 50f3bc14babc09ad316362d84c83ef8e5451594d..58b3034acfaef4e4c08f59d9dded47268d4536bc 100644 --- a/core/modules/taxonomy/src/Plugin/entity_reference/selection/TermSelection.php +++ b/core/modules/taxonomy/src/Plugin/entity_reference/selection/TermSelection.php @@ -60,7 +60,8 @@ public function getReferenceableEntities($match = NULL, $match_operator = 'CONTA $options = array(); $bundles = entity_get_bundles('taxonomy_term'); - $bundle_names = !empty($this->instance['settings']['handler_settings']['target_bundles']) ? $this->instance['settings']['handler_settings']['target_bundles'] : array_keys($bundles); + $handler_settings = $this->fieldDefinition->getSetting('handler_settings'); + $bundle_names = !empty($handler_settings['target_bundles']) ? $handler_settings['target_bundles'] : array_keys($bundles); foreach ($bundle_names as $bundle) { if ($vocabulary = entity_load('taxonomy_vocabulary', $bundle)) { diff --git a/core/modules/taxonomy/src/Tests/TermEntityReferenceTest.php b/core/modules/taxonomy/src/Tests/TermEntityReferenceTest.php new file mode 100644 index 0000000000000000000000000000000000000000..5f4e9300351f37e4a62cdc488ab46ca262a922d7 --- /dev/null +++ b/core/modules/taxonomy/src/Tests/TermEntityReferenceTest.php @@ -0,0 +1,83 @@ +createVocabulary(); + $vocabulary2 = $this->createVocabulary(); + + $term = $this->createTerm($vocabulary); + $term2 = $this->createTerm($vocabulary2); + + // Create an entity reference field. + $field_name = 'taxonomy_' . $vocabulary->id(); + $field_storage = FieldStorageConfig::create(array( + 'field_name' => $field_name, + 'entity_type' => 'entity_test', + 'translatable' => FALSE, + 'settings' => array( + 'target_type' => 'taxonomy_term', + ), + 'type' => 'entity_reference', + 'cardinality' => 1, + )); + $field_storage->save(); + $field = FieldConfig::create(array( + 'field_storage' => $field_storage, + 'entity_type' => 'entity_test', + 'bundle' => 'test_bundle', + 'settings' => array( + 'handler' => 'default', + 'handler_settings' => array( + // Restrict selection of terms to a single vocabulary. + 'target_bundles' => array( + $vocabulary->id() => $vocabulary->id(), + ), + ), + ), + )); + $field->save(); + + $handler = $this->container->get('plugin.manager.entity_reference.selection')->getSelectionHandler($field); + $result = $handler->getReferenceableEntities(); + + $expected_result = array( + $vocabulary->id() => array( + $term->id() => $term->getName(), + ), + ); + + $this->assertIdentical($result, $expected_result, 'Terms selection restricted to a single vocabulary.'); + } +}