2022-02-23 15:58:18 +00:00
|
|
|
<?php declare(strict_types=1);
|
2011-06-26 22:11:57 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Composer.
|
|
|
|
*
|
|
|
|
* (c) Nils Adermann <naderman@naderman.de>
|
|
|
|
* Jordi Boggiano <j.boggiano@seld.be>
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Composer\Test\DependencyResolver;
|
|
|
|
|
2017-02-16 22:00:57 +00:00
|
|
|
use Composer\DependencyResolver\GenericRule;
|
2011-06-26 22:11:57 +00:00
|
|
|
use Composer\DependencyResolver\Rule;
|
|
|
|
use Composer\DependencyResolver\RuleSet;
|
|
|
|
use Composer\DependencyResolver\RuleSetIterator;
|
2012-05-19 18:38:56 +00:00
|
|
|
use Composer\DependencyResolver\Pool;
|
2021-09-05 14:02:10 +00:00
|
|
|
use Composer\Semver\Constraint\MatchAllConstraint;
|
2020-02-07 03:18:45 +00:00
|
|
|
use Composer\Test\TestCase;
|
2011-06-26 22:11:57 +00:00
|
|
|
|
2017-11-04 14:52:13 +00:00
|
|
|
class RuleSetIteratorTest extends TestCase
|
2011-06-26 22:11:57 +00:00
|
|
|
{
|
2021-10-16 08:16:06 +00:00
|
|
|
/** @var array<RuleSet::TYPE_*, Rule[]> */
|
2011-06-26 22:11:57 +00:00
|
|
|
protected $rules;
|
2021-10-16 08:16:06 +00:00
|
|
|
/** @var Pool */
|
2018-01-06 14:05:39 +00:00
|
|
|
protected $pool;
|
2011-06-26 22:11:57 +00:00
|
|
|
|
2021-12-08 16:03:05 +00:00
|
|
|
protected function setUp(): void
|
2011-06-26 22:11:57 +00:00
|
|
|
{
|
2019-11-27 16:55:02 +00:00
|
|
|
$this->pool = new Pool();
|
2012-05-19 18:38:56 +00:00
|
|
|
|
2022-08-17 12:20:07 +00:00
|
|
|
$this->rules = [
|
|
|
|
RuleSet::TYPE_REQUEST => [
|
|
|
|
new GenericRule([], Rule::RULE_ROOT_REQUIRE, ['packageName' => '', 'constraint' => new MatchAllConstraint]),
|
|
|
|
new GenericRule([], Rule::RULE_ROOT_REQUIRE, ['packageName' => '', 'constraint' => new MatchAllConstraint]),
|
|
|
|
],
|
|
|
|
RuleSet::TYPE_LEARNED => [
|
|
|
|
new GenericRule([], Rule::RULE_LEARNED, 1),
|
|
|
|
],
|
|
|
|
RuleSet::TYPE_PACKAGE => [],
|
|
|
|
];
|
2011-06-26 22:11:57 +00:00
|
|
|
}
|
|
|
|
|
2022-02-18 09:38:54 +00:00
|
|
|
public function testForeach(): void
|
2011-06-26 22:11:57 +00:00
|
|
|
{
|
|
|
|
$ruleSetIterator = new RuleSetIterator($this->rules);
|
|
|
|
|
2022-08-17 12:20:07 +00:00
|
|
|
$result = [];
|
2012-01-23 08:21:36 +00:00
|
|
|
foreach ($ruleSetIterator as $rule) {
|
2011-06-26 22:11:57 +00:00
|
|
|
$result[] = $rule;
|
|
|
|
}
|
|
|
|
|
2022-08-17 12:20:07 +00:00
|
|
|
$expected = [
|
2020-01-19 22:11:36 +00:00
|
|
|
$this->rules[RuleSet::TYPE_REQUEST][0],
|
|
|
|
$this->rules[RuleSet::TYPE_REQUEST][1],
|
2012-04-27 16:28:18 +00:00
|
|
|
$this->rules[RuleSet::TYPE_LEARNED][0],
|
2022-08-17 12:20:07 +00:00
|
|
|
];
|
2011-06-26 22:11:57 +00:00
|
|
|
|
2024-05-29 21:12:06 +00:00
|
|
|
self::assertEquals($expected, $result);
|
2011-06-26 22:11:57 +00:00
|
|
|
}
|
2012-01-22 21:06:09 +00:00
|
|
|
|
2022-02-18 09:38:54 +00:00
|
|
|
public function testKeys(): void
|
2012-01-22 21:06:09 +00:00
|
|
|
{
|
|
|
|
$ruleSetIterator = new RuleSetIterator($this->rules);
|
|
|
|
|
2022-08-17 12:20:07 +00:00
|
|
|
$result = [];
|
2012-01-23 08:21:36 +00:00
|
|
|
foreach ($ruleSetIterator as $key => $rule) {
|
2012-01-22 21:06:09 +00:00
|
|
|
$result[] = $key;
|
|
|
|
}
|
|
|
|
|
2022-08-17 12:20:07 +00:00
|
|
|
$expected = [
|
2020-01-19 22:11:36 +00:00
|
|
|
RuleSet::TYPE_REQUEST,
|
|
|
|
RuleSet::TYPE_REQUEST,
|
2012-04-27 16:28:18 +00:00
|
|
|
RuleSet::TYPE_LEARNED,
|
2022-08-17 12:20:07 +00:00
|
|
|
];
|
2012-01-22 21:06:09 +00:00
|
|
|
|
2024-05-29 21:12:06 +00:00
|
|
|
self::assertEquals($expected, $result);
|
2012-01-22 21:06:09 +00:00
|
|
|
}
|
2011-06-26 22:11:57 +00:00
|
|
|
}
|