_calc = new CommitOrderCalculator(); } public function testCommitOrdering1() { $class1 = new ClassMetadata(NodeClass1::class); $class2 = new ClassMetadata(NodeClass2::class); $class3 = new ClassMetadata(NodeClass3::class); $class4 = new ClassMetadata(NodeClass4::class); $class5 = new ClassMetadata(NodeClass5::class); $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 = [$class5, $class1, $class2, $class3, $class4]; $this->assertSame($correctOrder, $sorted); } public function testCommitOrdering2() { $class1 = new ClassMetadata(NodeClass1::class); $class2 = new ClassMetadata(NodeClass2::class); $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 = [$class2, $class1]; $this->assertSame($correctOrder, $sorted); } } class NodeClass1 {} class NodeClass2 {} class NodeClass3 {} class NodeClass4 {} class NodeClass5 {}