// create a virtual directory and copy all needed files and folders to it
$this->root = vfsStream::setup('friendica', 0777, $structure);
- $this->setConfigFile('dbstructure.config.php', true);
- $this->setConfigFile('dbview.config.php', true);
- $this->setConfigFile('defaults.config.php', true);
- $this->setConfigFile('settings.config.php', true);
- $this->setConfigFile('local.config.php');
- $this->setDataFile('node.config.php');
- }
-
- protected function setDataFile(string $filename)
- {
- $file = dirname(__DIR__) . DIRECTORY_SEPARATOR .
- 'datasets' . DIRECTORY_SEPARATOR .
- 'config' . DIRECTORY_SEPARATOR .
- $filename;
-
- if (file_exists($file)) {
- vfsStream::newFile($filename)
- ->at($this->root->getChild('config'))
- ->setContent(file_get_contents($file));
- }
+ $this->setConfigFile('static' . DIRECTORY_SEPARATOR . 'dbstructure.config.php', true);
+ $this->setConfigFile('static' . DIRECTORY_SEPARATOR . 'dbview.config.php', true);
+ $this->setConfigFile('static' . DIRECTORY_SEPARATOR . 'defaults.config.php', true);
+ $this->setConfigFile('static' . DIRECTORY_SEPARATOR . 'settings.config.php', true);
+ $this->setConfigFile(
+ 'mods' . DIRECTORY_SEPARATOR . 'local.config.vagrant.php',
+ false, 'local.config.php'
+ );
}
/**
* Copying a config file from the file system to the Virtual File System
*
- * @param string $filename The filename of the config file
- * @param bool $static True, if the folder `static` instead of `config` should be used
+ * @param string $sourceFilePath The filename of the config file
+ * @param bool $static True, if the folder `static` instead of `config` should be used
*/
- protected function setConfigFile(string $filename, bool $static = false)
+ protected function setConfigFile(string $sourceFilePath, bool $static = false, string $targetFileName = null)
{
$file = dirname(__DIR__) . DIRECTORY_SEPARATOR .
'..' . DIRECTORY_SEPARATOR .
- ($static ? 'static' : 'config') . DIRECTORY_SEPARATOR .
- $filename;
+ $sourceFilePath;
if (file_exists($file)) {
- vfsStream::newFile($filename)
+ if (empty($targetFileName)) {
+ $tmpArray = preg_split('/\\' . DIRECTORY_SEPARATOR . '/', $sourceFilePath);
+ $targetFileName = array_pop($tmpArray);
+ }
+ vfsStream::newFile($targetFileName)
->at($this->root->getChild(($static ? 'static' : 'config')))
->setContent(file_get_contents($file));
+ } else {
+ throw new \Exception(sprintf('Unexpected missing config \'%s\'', $file));
}
}
->run($this->httpExceptionMock);
$json = $this->toJson($response);
- self::assertEquals('localhost', $json->site->server);
- self::assertEquals('frio', $json->site->theme);
+ self::assertEquals(DI::config()->get('config', 'hostname'), $json->site->server);
+ self::assertEquals(DI::config()->get('system', 'theme'), $json->site->theme);
self::assertEquals(DI::baseUrl() . '/images/friendica-64.png', $json->site->logo);
self::assertTrue($json->site->fancy);
- self::assertEquals('en', $json->site->language);
- self::assertEquals('UTC', $json->site->timezone);
+ self::assertEquals(DI::config()->get('system', 'language'), $json->site->language);
+ self::assertEquals(DI::config()->get('system', 'default_timezone'), $json->site->timezone);
self::assertEquals(200000, $json->site->textlimit);
self::assertFalse($json->site->private);
self::assertEquals('always', $json->site->ssl);