This should create relative/absolute dist URLs depending on the way (relative/absolute) the artifact directory path was given.
parent
9896abeb38
commit
beff1f5cc1
|
@ -96,7 +96,7 @@ class ArtifactRepository extends ArrayRepository
|
|||
$package = JsonFile::parseJson($json, $composerFile);
|
||||
$package['dist'] = array(
|
||||
'type' => 'zip',
|
||||
'url' => $file->getRealPath(),
|
||||
'url' => $file->getPathname(),
|
||||
'reference' => $file->getBasename(),
|
||||
'shasum' => sha1_file($file->getRealPath())
|
||||
);
|
||||
|
|
|
@ -16,6 +16,7 @@ use Composer\TestCase;
|
|||
use Composer\IO\NullIO;
|
||||
use Composer\Config;
|
||||
use Composer\Package\BasePackage;
|
||||
use Composer\Util\Filesystem;
|
||||
|
||||
class ArtifactRepositoryTest extends TestCase
|
||||
{
|
||||
|
@ -40,4 +41,27 @@ class ArtifactRepositoryTest extends TestCase
|
|||
|
||||
$this->assertSame($expectedPackages, $foundPackages);
|
||||
}
|
||||
|
||||
public function testAbsoluteRepoUrlCreatesAbsoluteUrlPackages()
|
||||
{
|
||||
$absolutePath = __DIR__ . '/Fixtures/artifacts';
|
||||
$coordinates = array('type' => 'artifact', 'url' => $absolutePath);
|
||||
$repo = new ArtifactRepository($coordinates, new NullIO(), new Config());
|
||||
|
||||
foreach ($repo->getPackages() as $package) {
|
||||
$this->assertTrue(strpos($package->getDistUrl(), $absolutePath) === 0);
|
||||
}
|
||||
}
|
||||
|
||||
public function testRelativeRepoUrlCreatesRelativeUrlPackages()
|
||||
{
|
||||
$relativePath = 'tests/Composer/Test/Repository/Fixtures/artifacts';
|
||||
$coordinates = array('type' => 'artifact', 'url' => $relativePath);
|
||||
$repo = new ArtifactRepository($coordinates, new NullIO(), new Config());
|
||||
|
||||
foreach ($repo->getPackages() as $package) {
|
||||
$this->assertTrue(strpos($package->getDistUrl(), $relativePath) === 0);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue