Add '<>' operator for Version Parser
parent
a06ebdd8ef
commit
e130386612
|
@ -228,7 +228,7 @@ class VersionParser
|
||||||
}
|
}
|
||||||
|
|
||||||
// match operators constraints
|
// match operators constraints
|
||||||
if (preg_match('{^(>=?|<=?|==?)?\s*(.*)}', $constraint, $matches)) {
|
if (preg_match('{^(<>|!=|>=?|<=?|==?)?\s*(.*)}', $constraint, $matches)) {
|
||||||
try {
|
try {
|
||||||
$version = $this->normalize($matches[2]);
|
$version = $this->normalize($matches[2]);
|
||||||
|
|
||||||
|
|
|
@ -115,6 +115,30 @@ class SolverTest extends TestCase
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testSolverInstallHonoursNotEqualOperator()
|
||||||
|
{
|
||||||
|
$this->repo->addPackage($packageA = $this->getPackage('A', '1.0'));
|
||||||
|
$this->repo->addPackage($packageB = $this->getPackage('B', '1.0'));
|
||||||
|
$this->repo->addPackage($newPackageB11 = $this->getPackage('B', '1.1'));
|
||||||
|
$this->repo->addPackage($newPackageB12 = $this->getPackage('B', '1.2'));
|
||||||
|
$this->repo->addPackage($newPackageB13 = $this->getPackage('B', '1.3'));
|
||||||
|
|
||||||
|
$packageA->setRequires(array(
|
||||||
|
new Link('A', 'B', $this->getVersionConstraint('<=', '1.3'), 'requires'),
|
||||||
|
new Link('A', 'B', $this->getVersionConstraint('<>', '1.3'), 'requires'),
|
||||||
|
new Link('A', 'B', $this->getVersionConstraint('!=', '1.2'), 'requires'),
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->reposComplete();
|
||||||
|
|
||||||
|
$this->request->install('A');
|
||||||
|
|
||||||
|
$this->checkSolverResult(array(
|
||||||
|
array('job' => 'install', 'package' => $newPackageB11),
|
||||||
|
array('job' => 'install', 'package' => $packageA),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
public function testSolverInstallWithDepsInOrder()
|
public function testSolverInstallWithDepsInOrder()
|
||||||
{
|
{
|
||||||
$this->repo->addPackage($packageA = $this->getPackage('A', '1.0'));
|
$this->repo->addPackage($packageA = $this->getPackage('A', '1.0'));
|
||||||
|
|
|
@ -143,6 +143,8 @@ class VersionParserTest extends \PHPUnit_Framework_TestCase
|
||||||
'match any/2' => array('*.*', new MultiConstraint(array())),
|
'match any/2' => array('*.*', new MultiConstraint(array())),
|
||||||
'match any/3' => array('*.x.*', new MultiConstraint(array())),
|
'match any/3' => array('*.x.*', new MultiConstraint(array())),
|
||||||
'match any/4' => array('x.x.x.*', new MultiConstraint(array())),
|
'match any/4' => array('x.x.x.*', new MultiConstraint(array())),
|
||||||
|
'not equal' => array('<>1.0.0', new VersionConstraint('<>', '1.0.0.0')),
|
||||||
|
'not equal/2' => array('!=1.0.0', new VersionConstraint('!=', '1.0.0.0')),
|
||||||
'greater than' => array('>1.0.0', new VersionConstraint('>', '1.0.0.0')),
|
'greater than' => array('>1.0.0', new VersionConstraint('>', '1.0.0.0')),
|
||||||
'lesser than' => array('<1.2.3.4', new VersionConstraint('<', '1.2.3.4')),
|
'lesser than' => array('<1.2.3.4', new VersionConstraint('<', '1.2.3.4')),
|
||||||
'less/eq than' => array('<=1.2.3', new VersionConstraint('<=', '1.2.3.0')),
|
'less/eq than' => array('<=1.2.3', new VersionConstraint('<=', '1.2.3.0')),
|
||||||
|
|
Loading…
Reference in New Issue