From adbebba6ad14a2cc3fae5a46eeaa1399be0f115d Mon Sep 17 00:00:00 2001 From: Dries Date: Mon, 23 Jan 2012 09:01:17 -0500 Subject: [PATCH] - Patch #1330554 by oriol_e9g, fiftyz, richthegeek: Fixed taxonomy_get_tree() incorrect depth on multiple parents. --- core/modules/taxonomy/taxonomy.module | 6 +-- core/modules/taxonomy/taxonomy.test | 54 +++++++++++++++++++++++++++ 2 files changed, 57 insertions(+), 3 deletions(-) diff --git a/core/modules/taxonomy/taxonomy.module b/core/modules/taxonomy/taxonomy.module index 338638f6c8b..606abfc017e 100644 --- a/core/modules/taxonomy/taxonomy.module +++ b/core/modules/taxonomy/taxonomy.module @@ -1048,9 +1048,9 @@ function taxonomy_get_tree($vid, $parent = 0, $max_depth = NULL, $load_entities break; } $term = $load_entities ? $term_entities[$child] : $terms[$vid][$child]; - if (count($parents[$vid][$term->tid]) > 1) { - // We have a term with multi parents here. Clone the term, - // so that the depth attribute remains correct. + if (isset($parents[$vid][$term->tid])) { + // Clone the term so that the depth attribute remains correct + // in the event of multiple parents. $term = clone $term; } $term->depth = $depth; diff --git a/core/modules/taxonomy/taxonomy.test b/core/modules/taxonomy/taxonomy.test index a7f7bd9d6be..aa3c20993a6 100644 --- a/core/modules/taxonomy/taxonomy.test +++ b/core/modules/taxonomy/taxonomy.test @@ -416,6 +416,60 @@ class TaxonomyTermUnitTest extends TaxonomyWebTestCase { // Delete an invalid term. Should not throw any notices. taxonomy_term_delete(42); } + + /** + * Test a taxonomy with terms that have multiple parents of different depths. + */ + function testTaxonomyVocabularyTree() { + // Create a new vocabulary with 6 terms. + $vocabulary = $this->createVocabulary(); + $term = array(); + for ($i = 0; $i < 6; $i++) { + $term[$i] = $this->createTerm($vocabulary); + } + + // $term[2] is a child of 1 and 5. + $term[2]->parent = array($term[1]->tid, $term[5]->tid); + taxonomy_term_save($term[2]); + // $term[3] is a child of 2. + $term[3]->parent = array($term[2]->tid); + taxonomy_term_save($term[3]); + // $term[5] is a child of 4. + $term[5]->parent = array($term[4]->tid); + taxonomy_term_save($term[5]); + + /** + * Expected tree: + * term[0] | depth: 0 + * term[1] | depth: 0 + * -- term[2] | depth: 1 + * ---- term[3] | depth: 2 + * term[4] | depth: 0 + * -- term[5] | depth: 1 + * ---- term[2] | depth: 2 + * ------ term[3] | depth: 3 + */ + + // Count $term[1] parents with $max_depth = 1. + $tree = taxonomy_get_tree($vocabulary->vid, $term[1]->tid, 1); + $this->assertEqual(1, count($tree), 'We have one parent with depth 1.'); + + // Count all vocabulary tree elements. + $tree = taxonomy_get_tree($vocabulary->vid); + $this->assertEqual(8, count($tree), 'We have all vocabulary tree elements.'); + + // Count elements in every tree depth. + foreach($tree as $element) { + if (!isset($depth_count[$element->depth])) { + $depth_count[$element->depth] = 0; + } + $depth_count[$element->depth]++; + } + $this->assertEqual(3, $depth_count[0], 'Three elements in taxonomy tree depth 0.'); + $this->assertEqual(2, $depth_count[1], 'Two elements in taxonomy tree depth 1.'); + $this->assertEqual(2, $depth_count[2], 'Two elements in taxonomy tree depth 2.'); + $this->assertEqual(1, $depth_count[3], 'One element in taxonomy tree depth 3.'); + } } /**