_calc = new CommitOrderCalculator(); } public function testCommitOrdering1() { $class1 = new ClassMetadata(__NAMESPACE__ . '\NodeClass1'); $class2 = new ClassMetadata(__NAMESPACE__ . '\NodeClass2'); $class3 = new ClassMetadata(__NAMESPACE__ . '\NodeClass3'); $class4 = new ClassMetadata(__NAMESPACE__ . '\NodeClass4'); $class5 = new ClassMetadata(__NAMESPACE__ . '\NodeClass5'); $this->_calc->addNode($class1->name, $class1); $this->_calc->addNode($class2->name, $class2); $this->_calc->addNode($class3->name, $class3); $this->_calc->addNode($class4->name, $class4); $this->_calc->addNode($class5->name, $class5); $this->_calc->addDependency($class1->name, $class2->name, 1); $this->_calc->addDependency($class2->name, $class3->name, 1); $this->_calc->addDependency($class3->name, $class4->name, 1); $this->_calc->addDependency($class5->name, $class1->name, 1); $sorted = $this->_calc->sort(); // There is only 1 valid ordering for this constellation $correctOrder = array($class5, $class1, $class2, $class3, $class4); $this->assertSame($correctOrder, $sorted); } public function testCommitOrdering2() { $class1 = new ClassMetadata(__NAMESPACE__ . '\NodeClass1'); $class2 = new ClassMetadata(__NAMESPACE__ . '\NodeClass2'); $this->_calc->addNode($class1->name, $class1); $this->_calc->addNode($class2->name, $class2); $this->_calc->addDependency($class1->name, $class2->name, 0); $this->_calc->addDependency($class2->name, $class1->name, 1); $sorted = $this->_calc->sort(); // There is only 1 valid ordering for this constellation $correctOrder = array($class2, $class1); $this->assertSame($correctOrder, $sorted); } } class NodeClass1 {} class NodeClass2 {} class NodeClass3 {} class NodeClass4 {} class NodeClass5 {}