mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
741166e369
NEW: URL generation now handled by pluggable ResourceURLGenerator service. NEW: Requirements::javascript() and Requirements::css() now support “vendor/package:resource” syntax. These changes will make it easier to us to fully abstract: - file access from module location - file location from URL generation API: ModulePath template global now takes any composer package name. NEW: URL generation now handled by pluggable ResourceURLGenerator service. NEW: Requirements::javascript() and Requirements::css() now support “vendor/package:resource” syntax. These changes will make it easier to us to fully abstract: - file access from module location - file location from URL generation
103 lines
3.0 KiB
PHP
103 lines
3.0 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\Core\Tests\Manifest;
|
|
|
|
use SilverStripe\Core\Manifest\ModuleManifest;
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
class ModuleManifestTest extends SapphireTest
|
|
{
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $base;
|
|
|
|
/**
|
|
* @var ModuleManifest
|
|
*/
|
|
protected $manifest;
|
|
|
|
protected function setUp()
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->base = dirname(__FILE__) . '/fixtures/classmanifest';
|
|
$this->manifest = new ModuleManifest($this->base);
|
|
$this->manifest->init();
|
|
}
|
|
|
|
public function testGetModules()
|
|
{
|
|
$modules = $this->manifest->getModules();
|
|
$this->assertEquals(
|
|
[
|
|
'silverstripe/root-module',
|
|
'module',
|
|
'silverstripe/awesome-module',
|
|
],
|
|
array_keys($modules)
|
|
);
|
|
}
|
|
|
|
public function testGetLegacyModule()
|
|
{
|
|
$module = $this->manifest->getModule('module');
|
|
$this->assertNotEmpty($module);
|
|
$this->assertEquals('module', $module->getName());
|
|
$this->assertEquals('module', $module->getShortName());
|
|
$this->assertEquals('module', $module->getRelativePath());
|
|
$this->assertEmpty($module->getComposerName());
|
|
}
|
|
|
|
public function testGetComposerModule()
|
|
{
|
|
// Get by installer-name (folder)
|
|
$moduleByShortName = $this->manifest->getModule('moduleb');
|
|
$this->assertNotEmpty($moduleByShortName);
|
|
|
|
// Can also get this by full composer name
|
|
$module = $this->manifest->getModule('silverstripe/awesome-module');
|
|
$this->assertNotEmpty($module);
|
|
$this->assertEquals($moduleByShortName->getPath(), $module->getPath());
|
|
|
|
// correctly respects vendor
|
|
$this->assertEmpty($this->manifest->getModule('wrongvendor/awesome-module'));
|
|
$this->assertEmpty($this->manifest->getModule('wrongvendor/moduleb'));
|
|
|
|
// Properties of module
|
|
$this->assertEquals('silverstripe/awesome-module', $module->getName());
|
|
$this->assertEquals('silverstripe/awesome-module', $module->getComposerName());
|
|
$this->assertEquals('moduleb', $module->getShortName());
|
|
$this->assertEquals('moduleb', $module->getRelativePath());
|
|
}
|
|
|
|
/*
|
|
* Note: Tests experimental API
|
|
* @internal
|
|
*/
|
|
public function testGetResourcePath()
|
|
{
|
|
$module = $this->manifest->getModule('moduleb');
|
|
$this->assertTrue($module->hasResource('composer.json'));
|
|
$this->assertFalse($module->hasResource('package.json'));
|
|
$this->assertEquals(
|
|
'moduleb/composer.json',
|
|
$module->getRelativeResourcePath('composer.json')
|
|
);
|
|
}
|
|
|
|
/*
|
|
* Note: Tests experimental API
|
|
* @internal
|
|
*/
|
|
public function testGetResourcePathOnRoot()
|
|
{
|
|
$module = $this->manifest->getModule('silverstripe/root-module');
|
|
$this->assertTrue($module->hasResource('composer.json'));
|
|
$this->assertEquals(
|
|
'composer.json',
|
|
$module->getRelativeResourcePath('composer.json')
|
|
);
|
|
}
|
|
}
|