RuleSetTest.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <?php
  2. /*
  3. * This file is part of Composer.
  4. *
  5. * (c) Nils Adermann <naderman@naderman.de>
  6. * Jordi Boggiano <j.boggiano@seld.be>
  7. *
  8. * For the full copyright and license information, please view the LICENSE
  9. * file that was distributed with this source code.
  10. */
  11. namespace Composer\Test\DependencyResolver;
  12. use Composer\DependencyResolver\Rule;
  13. use Composer\DependencyResolver\RuleSet;
  14. use Composer\DependencyResolver\Literal;
  15. use Composer\Test\TestCase;
  16. class RuleSetTest extends TestCase
  17. {
  18. public function testAdd()
  19. {
  20. $rules = array(
  21. RuleSet::TYPE_PACKAGE => array(),
  22. RuleSet::TYPE_JOB => array(
  23. new Rule(array(), 'job1', null),
  24. new Rule(array(), 'job2', null),
  25. ),
  26. RuleSet::TYPE_UPDATE => array(
  27. new Rule(array(), 'update1', null),
  28. ),
  29. RuleSet::TYPE_FEATURE => array(),
  30. RuleSet::TYPE_LEARNED => array(),
  31. RuleSet::TYPE_CHOICE => array(),
  32. );
  33. $ruleSet = new RuleSet;
  34. $ruleSet->add($rules[RuleSet::TYPE_JOB][0], RuleSet::TYPE_JOB);
  35. $ruleSet->add($rules[RuleSet::TYPE_UPDATE][0], RuleSet::TYPE_UPDATE);
  36. $ruleSet->add($rules[RuleSet::TYPE_JOB][1], RuleSet::TYPE_JOB);
  37. $this->assertEquals($rules, $ruleSet->getRules());
  38. }
  39. /**
  40. * @expectedException \OutOfBoundsException
  41. */
  42. public function testAddWhenTypeIsNotRecognized()
  43. {
  44. $ruleSet = new RuleSet;
  45. $ruleSet->add(new Rule(array(), 'job1', null), 7);
  46. }
  47. public function testAddWhenTypeIsUnknow()
  48. {
  49. $ruleSet = new RuleSet;
  50. $rule = new Rule(array(), 'job1', null);
  51. $ruleSet->add($rule, -1);
  52. $rules = $ruleSet->getRules();
  53. $this->assertSame($rule, $rules[-1][0]);
  54. }
  55. public function testCount()
  56. {
  57. $ruleSet = new RuleSet;
  58. $ruleSet->add(new Rule(array(), 'job1', null), RuleSet::TYPE_JOB);
  59. $ruleSet->add(new Rule(array(), 'job2', null), RuleSet::TYPE_JOB);
  60. $this->assertEquals(2, $ruleSet->count());
  61. }
  62. public function testRuleById()
  63. {
  64. $ruleSet = new RuleSet;
  65. $rule = new Rule(array(), 'job1', null);
  66. $ruleSet->add($rule, RuleSet::TYPE_JOB);
  67. $this->assertSame($rule, $ruleSet->ruleById(0));
  68. }
  69. public function testGetIterator()
  70. {
  71. $ruleSet = new RuleSet;
  72. $rule1 = new Rule(array(), 'job1', null);
  73. $rule2 = new Rule(array(), 'job1', null);
  74. $ruleSet->add($rule1, RuleSet::TYPE_JOB);
  75. $ruleSet->add($rule2, RuleSet::TYPE_UPDATE);
  76. $iterator = $ruleSet->getIterator();
  77. $this->assertSame($rule1, $iterator->current());
  78. $iterator->next();
  79. $this->assertSame($rule2, $iterator->current());
  80. }
  81. public function testGetIteratorFor()
  82. {
  83. $ruleSet = new RuleSet;
  84. $rule1 = new Rule(array(), 'job1', null);
  85. $rule2 = new Rule(array(), 'job1', null);
  86. $ruleSet->add($rule1, RuleSet::TYPE_JOB);
  87. $ruleSet->add($rule2, RuleSet::TYPE_UPDATE);
  88. $iterator = $ruleSet->getIteratorFor(RuleSet::TYPE_UPDATE);
  89. $this->assertSame($rule2, $iterator->current());
  90. }
  91. public function testGetIteratorWithout()
  92. {
  93. $ruleSet = new RuleSet;
  94. $rule1 = new Rule(array(), 'job1', null);
  95. $rule2 = new Rule(array(), 'job1', null);
  96. $ruleSet->add($rule1, RuleSet::TYPE_JOB);
  97. $ruleSet->add($rule2, RuleSet::TYPE_UPDATE);
  98. $iterator = $ruleSet->getIteratorWithout(RuleSet::TYPE_JOB);
  99. $this->assertSame($rule2, $iterator->current());
  100. }
  101. public function testContainsEqual()
  102. {
  103. $ruleSet = new RuleSet;
  104. $rule = $this->getRuleMock();
  105. $rule->expects($this->any())
  106. ->method('getHash')
  107. ->will($this->returnValue('rule_1_hash'));
  108. $rule->expects($this->any())
  109. ->method('equals')
  110. ->will($this->returnValue(true));
  111. $rule2 = $this->getRuleMock();
  112. $rule2->expects($this->any())
  113. ->method('getHash')
  114. ->will($this->returnValue('rule_2_hash'));
  115. $rule3 = $this->getRuleMock();
  116. $rule3->expects($this->any())
  117. ->method('getHash')
  118. ->will($this->returnValue('rule_1_hash'));
  119. $rule3->expects($this->any())
  120. ->method('equal')
  121. ->will($this->returnValue(false));
  122. $ruleSet->add($rule, RuleSet::TYPE_UPDATE);
  123. $this->assertTrue($ruleSet->containsEqual($rule));
  124. $this->assertFalse($ruleSet->containsEqual($rule2));
  125. $this->assertFalse($ruleSet->containsEqual($rule3));
  126. }
  127. public function testToString()
  128. {
  129. $ruleSet = new RuleSet;
  130. $literal = new Literal($this->getPackage('foo', '2.1'), true);
  131. $rule = new Rule(array($literal), 'job1', null);
  132. $ruleSet->add($rule, RuleSet::TYPE_UPDATE);
  133. $this->assertContains('UPDATE : (+foo-2.1.0.0)', $ruleSet->__toString());
  134. }
  135. private function getRuleMock()
  136. {
  137. return $this->getMockBuilder('Composer\DependencyResolver\Rule')
  138. ->disableOriginalConstructor()
  139. ->getMock();
  140. }
  141. }