1
0
Fork 0
composer/tests/Composer/Test/Package/CompletePackageTest.php

108 lines
3.4 KiB
PHP
Raw Normal View History

2022-02-23 15:58:18 +00:00
<?php declare(strict_types=1);
/*
2011-04-16 12:42:35 +00:00
* This file is part of Composer.
*
2011-04-16 12:42:35 +00:00
* (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.
*/
2011-04-17 21:45:37 +00:00
namespace Composer\Test\Package;
use Composer\Package\Package;
use Composer\Semver\VersionParser;
use Composer\Test\TestCase;
class CompletePackageTest extends TestCase
{
/**
* Memory package naming, versioning, and marshalling semantics provider
*
* demonstrates several versioning schemes
*/
2022-02-21 12:42:28 +00:00
public function providerVersioningSchemes(): array
{
$provider[] = array('foo', '1-beta');
$provider[] = array('node', '0.5.6');
$provider[] = array('li3', '0.10');
$provider[] = array('mongodb_odm', '1.0.0BETA3');
$provider[] = array('DoctrineCommon', '2.2.0-DEV');
return $provider;
}
/**
* @dataProvider providerVersioningSchemes
2021-11-01 20:44:12 +00:00
*
* @param string $name
* @param string $version
*/
2022-02-22 15:47:09 +00:00
public function testPackageHasExpectedNamingSemantics(string $name, string $version): void
{
$versionParser = new VersionParser();
$normVersion = $versionParser->normalize($version);
$package = new Package($name, $normVersion, $version);
$this->assertEquals(strtolower($name), $package->getName());
}
/**
* @dataProvider providerVersioningSchemes
2021-11-01 20:44:12 +00:00
*
* @param string $name
* @param string $version
*/
2022-02-22 15:47:09 +00:00
public function testPackageHasExpectedVersioningSemantics(string $name, string $version): void
{
$versionParser = new VersionParser();
$normVersion = $versionParser->normalize($version);
$package = new Package($name, $normVersion, $version);
$this->assertEquals($version, $package->getPrettyVersion());
$this->assertEquals($normVersion, $package->getVersion());
}
/**
* @dataProvider providerVersioningSchemes
2021-11-01 20:44:12 +00:00
*
* @param string $name
* @param string $version
*/
2022-02-22 15:47:09 +00:00
public function testPackageHasExpectedMarshallingSemantics(string $name, string $version): void
{
$versionParser = new VersionParser();
$normVersion = $versionParser->normalize($version);
$package = new Package($name, $normVersion, $version);
$this->assertEquals(strtolower($name).'-'.$normVersion, (string) $package);
}
public function testGetTargetDir(): void
{
$package = new Package('a', '1.0.0.0', '1.0');
$this->assertNull($package->getTargetDir());
$package->setTargetDir('./../foo/');
$this->assertEquals('foo/', $package->getTargetDir());
$package->setTargetDir('foo/../../../bar/');
$this->assertEquals('foo/bar/', $package->getTargetDir());
$package->setTargetDir('../..');
$this->assertEquals('', $package->getTargetDir());
2012-09-18 16:32:24 +00:00
$package->setTargetDir('..');
$this->assertEquals('', $package->getTargetDir());
$package->setTargetDir('/..');
$this->assertEquals('', $package->getTargetDir());
$package->setTargetDir('/foo/..');
$this->assertEquals('foo/', $package->getTargetDir());
$package->setTargetDir('/foo/..//bar');
$this->assertEquals('foo/bar', $package->getTargetDir());
}
}