RuleSetTest.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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\Pool;
  15. use Composer\Repository\ArrayRepository;
  16. use Composer\TestCase;
  17. class RuleSetTest extends TestCase
  18. {
  19. protected $pool;
  20. public function setUp()
  21. {
  22. $this->pool = new Pool;
  23. }
  24. public function testAdd()
  25. {
  26. $rules = array(
  27. RuleSet::TYPE_PACKAGE => array(),
  28. RuleSet::TYPE_JOB => array(
  29. new Rule(array(1), Rule::RULE_JOB_INSTALL, null),
  30. new Rule(array(2), Rule::RULE_JOB_INSTALL, null),
  31. ),
  32. RuleSet::TYPE_LEARNED => array(
  33. new Rule(array(), Rule::RULE_INTERNAL_ALLOW_UPDATE, null),
  34. ),
  35. );
  36. $ruleSet = new RuleSet;
  37. $ruleSet->add($rules[RuleSet::TYPE_JOB][0], RuleSet::TYPE_JOB);
  38. $ruleSet->add($rules[RuleSet::TYPE_LEARNED][0], RuleSet::TYPE_LEARNED);
  39. $ruleSet->add($rules[RuleSet::TYPE_JOB][1], RuleSet::TYPE_JOB);
  40. $this->assertEquals($rules, $ruleSet->getRules());
  41. }
  42. public function testAddIgnoresDuplicates()
  43. {
  44. $rules = array(
  45. RuleSet::TYPE_JOB => array(
  46. new Rule(array(), Rule::RULE_JOB_INSTALL, null),
  47. new Rule(array(), Rule::RULE_JOB_INSTALL, null),
  48. new Rule(array(), Rule::RULE_JOB_INSTALL, null),
  49. )
  50. );
  51. $ruleSet = new RuleSet;
  52. $ruleSet->add($rules[RuleSet::TYPE_JOB][0], RuleSet::TYPE_JOB);
  53. $ruleSet->add($rules[RuleSet::TYPE_JOB][1], RuleSet::TYPE_JOB);
  54. $ruleSet->add($rules[RuleSet::TYPE_JOB][2], RuleSet::TYPE_JOB);
  55. $this->assertCount(1, $ruleSet->getIteratorFor(array(RuleSet::TYPE_JOB)));
  56. }
  57. /**
  58. * @expectedException \OutOfBoundsException
  59. */
  60. public function testAddWhenTypeIsNotRecognized()
  61. {
  62. $ruleSet = new RuleSet;
  63. $ruleSet->add(new Rule(array(), Rule::RULE_JOB_INSTALL, null), 7);
  64. }
  65. public function testCount()
  66. {
  67. $ruleSet = new RuleSet;
  68. $ruleSet->add(new Rule(array(1), Rule::RULE_JOB_INSTALL, null), RuleSet::TYPE_JOB);
  69. $ruleSet->add(new Rule(array(2), Rule::RULE_JOB_INSTALL, null), RuleSet::TYPE_JOB);
  70. $this->assertEquals(2, $ruleSet->count());
  71. }
  72. public function testRuleById()
  73. {
  74. $ruleSet = new RuleSet;
  75. $rule = new Rule(array(), Rule::RULE_JOB_INSTALL, null);
  76. $ruleSet->add($rule, RuleSet::TYPE_JOB);
  77. $this->assertSame($rule, $ruleSet->ruleById[0]);
  78. }
  79. public function testGetIterator()
  80. {
  81. $ruleSet = new RuleSet;
  82. $rule1 = new Rule(array(1), Rule::RULE_JOB_INSTALL, null);
  83. $rule2 = new Rule(array(2), Rule::RULE_JOB_INSTALL, null);
  84. $ruleSet->add($rule1, RuleSet::TYPE_JOB);
  85. $ruleSet->add($rule2, RuleSet::TYPE_LEARNED);
  86. $iterator = $ruleSet->getIterator();
  87. $this->assertSame($rule1, $iterator->current());
  88. $iterator->next();
  89. $this->assertSame($rule2, $iterator->current());
  90. }
  91. public function testGetIteratorFor()
  92. {
  93. $ruleSet = new RuleSet;
  94. $rule1 = new Rule(array(1), Rule::RULE_JOB_INSTALL, null);
  95. $rule2 = new Rule(array(2), Rule::RULE_JOB_INSTALL, null);
  96. $ruleSet->add($rule1, RuleSet::TYPE_JOB);
  97. $ruleSet->add($rule2, RuleSet::TYPE_LEARNED);
  98. $iterator = $ruleSet->getIteratorFor(RuleSet::TYPE_LEARNED);
  99. $this->assertSame($rule2, $iterator->current());
  100. }
  101. public function testGetIteratorWithout()
  102. {
  103. $ruleSet = new RuleSet;
  104. $rule1 = new Rule(array(1), Rule::RULE_JOB_INSTALL, null);
  105. $rule2 = new Rule(array(2), Rule::RULE_JOB_INSTALL, null);
  106. $ruleSet->add($rule1, RuleSet::TYPE_JOB);
  107. $ruleSet->add($rule2, RuleSet::TYPE_LEARNED);
  108. $iterator = $ruleSet->getIteratorWithout(RuleSet::TYPE_JOB);
  109. $this->assertSame($rule2, $iterator->current());
  110. }
  111. public function testPrettyString()
  112. {
  113. $repo = new ArrayRepository;
  114. $repo->addPackage($p = $this->getPackage('foo', '2.1'));
  115. $this->pool->addRepository($repo);
  116. $ruleSet = new RuleSet;
  117. $literal = $p->getId();
  118. $rule = new Rule(array($literal), Rule::RULE_JOB_INSTALL, null);
  119. $ruleSet->add($rule, RuleSet::TYPE_JOB);
  120. $this->assertContains('JOB : Install command rule (install foo 2.1)', $ruleSet->getPrettyString($this->pool));
  121. }
  122. private function getRuleMock()
  123. {
  124. return $this->getMockBuilder('Composer\DependencyResolver\Rule')
  125. ->disableOriginalConstructor()
  126. ->getMock();
  127. }
  128. }