Skip to content
This repository has been archived by the owner on Jan 29, 2020. It is now read-only.

Commit

Permalink
Merge remote-tracking branch 'evandotpro/feature/config-factory-retur…
Browse files Browse the repository at this point in the history
…n-object'
  • Loading branch information
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 9 deletions.
22 changes: 13 additions & 9 deletions src/Factory.php
Expand Up @@ -43,10 +43,11 @@ abstract class Factory
/**
* Read a config from a file.
*
* @param string $filename
* @return array
* @param string $filename
* @param boolean $returnConfigObject
* @return array|Config
*/
public static function fromFile($filename)
public static function fromFile($filename, $returnConfigObject = false)
{
$pathinfo = pathinfo($filename);

Expand All @@ -64,36 +65,39 @@ public static function fromFile($filename)
throw new Exception\RuntimeException(sprintf('Filename "%s" is either not a file or not readable', $filename));
}

return include $filename;
$config = include $filename;
} elseif (isset(self::$readers[$extension])) {
if (is_string(self::$readers[$extension])) {
$classname = __NAMESPACE__ . '\\Reader\\' . self::$readers[$extension];
self::$readers[$extension] = new $classname();
}

return self::$readers[$extension]->fromFile($filename);
$config = self::$readers[$extension]->fromFile($filename);
} else {
throw new Exception\RuntimeException(sprintf(
'Unsupported config file extension: .%s',
$pathinfo['extension']
));
}

return ($returnConfigObject) ? new Config($config) : $config;
}

/**
* Read configuration from multiple files and merge them.
*
* @param array $files
* @return array
* @param array $files
* @param boolean $returnConfigObject
* @return array|Config
*/
public static function fromFiles(array $files)
public static function fromFiles(array $files, $returnConfigObject = false)
{
$config = array();

foreach ($files as $file) {
$config = array_replace_recursive($config, self::fromFile($file));
}

return $config;
return ($returnConfigObject) ? new Config($config) : $config;
}
}
19 changes: 19 additions & 0 deletions test/FactoryTest.php
Expand Up @@ -100,6 +100,25 @@ public function testFromIniAndXmlAndPhpFiles()
$this->assertEquals('baz', $config['last']['bar']);
}

public function testReturnsConfigObjectIfRequestedAndArrayOtherwise()
{
$files = array (
__DIR__ . '/TestAssets/Ini/include-base.ini',
);

$configArray = Factory::fromFile($files[0]);
$this->assertTrue(is_array($configArray));

$configArray = Factory::fromFiles($files);
$this->assertTrue(is_array($configArray));

$configObject = Factory::fromFile($files[0], true);
$this->assertInstanceOf('Zend\Config\Config', $configObject);

$configObject = Factory::fromFiles($files, true);
$this->assertInstanceOf('Zend\Config\Config', $configObject);
}

public function testNonExistentFileThrowsRuntimeException()
{
$this->setExpectedException('RuntimeException');
Expand Down

0 comments on commit 7974490

Please sign in to comment.