<?php
+/**
+ * @copyright Copyright (C) 2020, Friendica
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
// this is in the same namespace as Install for mocking 'function_exists'
namespace Friendica\Core;
+use Dice\Dice;
+use Friendica\Core\Config\Cache;
+use Friendica\DI;
+use Friendica\Network\CurlResult;
use Friendica\Test\MockedTest;
-use Friendica\Test\Util\L10nMockTrait;
use Friendica\Test\Util\VFSTrait;
+use Friendica\Util\Network;
+use Mockery\MockInterface;
-/**
- * @runTestsInSeparateProcesses
- * @preserveGlobalState disabled
- */
class InstallerTest extends MockedTest
{
use VFSTrait;
- use L10nMockTrait;
+
+ /**
+ * @var \Friendica\Core\L10n|MockInterface
+ */
+ private $l10nMock;
public function setUp()
{
parent::setUp();
$this->setUpVfsDir();
+
+ $this->l10nMock = \Mockery::mock(\Friendica\Core\L10n::class);
+
+ /** @var Dice|MockInterface $dice */
+ $dice = \Mockery::mock(Dice::class)->makePartial();
+ $dice = $dice->addRules(include __DIR__ . '/../../../static/dependencies.config.php');
+
+ $dice->shouldReceive('create')
+ ->with(\Friendica\Core\L10n::class)
+ ->andReturn($this->l10nMock);
+
+ DI::init($dice);
+ }
+
+ private function mockL10nT(string $text, $times = null)
+ {
+ $this->l10nMock->shouldReceive('t')->with($text)->andReturn($text)->times($times);
}
/**
- * Mocking the L10n::t() calls for the function checks
+ * Mocking the DI::l10n()->t() calls for the function checks
*/
private function mockFunctionL10TCalls()
{
$this->mockL10nT('Error: iconv PHP module required but not installed.', 1);
$this->mockL10nT('POSIX PHP module', 1);
$this->mockL10nT('Error: POSIX PHP module required but not installed.', 1);
+ $this->mockL10nT('JSON PHP module', 1);
+ $this->mockL10nT('Error: JSON PHP module required but not installed.', 1);
+ $this->mockL10nT('File Information PHP module', 1);
+ $this->mockL10nT('Error: File Information PHP module required but not installed.', 1);
}
private function assertCheckExist($position, $title, $help, $status, $required, $assertionArray)
{
- $this->assertArraySubset([$position => [
+ $subSet = [$position => [
'title' => $title,
'status' => $status,
'required' => $required,
'error_msg' => null,
'help' => $help]
- ], $assertionArray);
+ ];
+
+ $this->assertArraySubset($subSet, $assertionArray, false, "expected subset: " . PHP_EOL . print_r($subSet, true) . PHP_EOL . "current subset: " . print_r($assertionArray, true));
}
/**
*/
public function testCheckKeys()
{
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
+
$this->setFunctions(['openssl_pkey_new' => false]);
$install = new Installer();
$this->assertFalse($install->checkKeys());
true,
$install->getChecks());
+ $this->mockFunctionL10TCalls();
+ $this->setFunctions(['json_encode' => false]);
+ $install = new Installer();
+ $this->assertFalse($install->checkFunctions());
+ $this->assertCheckExist(9,
+ 'JSON PHP module',
+ 'Error: JSON PHP module required but not installed.',
+ false,
+ true,
+ $install->getChecks());
+
+ $this->mockFunctionL10TCalls();
+ $this->setFunctions(['finfo_open' => false]);
+ $install = new Installer();
+ $this->assertFalse($install->checkFunctions());
+ $this->assertCheckExist(10,
+ 'File Information PHP module',
+ 'Error: File Information PHP module required but not installed.',
+ false,
+ true,
+ $install->getChecks());
+
$this->mockFunctionL10TCalls();
$this->setFunctions([
'curl_init' => true,
'openssl_public_encrypt' => true,
'mb_strlen' => true,
'iconv_strlen' => true,
- 'posix_kill' => true
+ 'posix_kill' => true,
+ 'json_encode' => true,
+ 'finfo_open' => true,
]);
$install = new Installer();
$this->assertTrue($install->checkFunctions());
*/
public function testCheckLocalIni()
{
- $this->assertTrue($this->root->hasChild('config/local.ini.php'));
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
+
+ $this->assertTrue($this->root->hasChild('config/local.config.php'));
$install = new Installer();
$this->assertTrue($install->checkLocalIni());
- $this->delConfigFile('local.ini.php');
+ $this->delConfigFile('local.config.php');
- $this->assertFalse($this->root->hasChild('config/local.ini.php'));
+ $this->assertFalse($this->root->hasChild('config/local.config.php'));
$install = new Installer();
$this->assertTrue($install->checkLocalIni());
/**
* @small
+ * @runInSeparateProcess
+ * @preserveGlobalState disabled
*/
public function testCheckHtAccessFail()
{
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
+
// Mocking the CURL Response
- $curlResult = \Mockery::mock('Friendica\Network\CurlResult');
+ $curlResult = \Mockery::mock(CurlResult::class);
$curlResult
->shouldReceive('getReturnCode')
->andReturn('404');
->andReturn('test Error');
// Mocking the CURL Request
- $networkMock = \Mockery::mock('alias:Friendica\Util\Network');
+ $networkMock = \Mockery::mock('alias:' . Network::class);
$networkMock
->shouldReceive('fetchUrlFull')
->with('https://test/install/testrewrite')
// Mocking that we can use CURL
$this->setFunctions(['curl_init' => true]);
- // needed because of "normalise_link"
- require_once __DIR__ . '/../../../include/text.php';
-
$install = new Installer();
$this->assertFalse($install->checkHtAccess('https://test'));
/**
* @small
+ * @runInSeparateProcess
+ * @preserveGlobalState disabled
*/
public function testCheckHtAccessWork()
{
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
+
// Mocking the failed CURL Response
- $curlResultF = \Mockery::mock('Friendica\Network\CurlResult');
+ $curlResultF = \Mockery::mock(CurlResult::class);
$curlResultF
->shouldReceive('getReturnCode')
->andReturn('404');
// Mocking the working CURL Response
- $curlResultW = \Mockery::mock('Friendica\Network\CurlResult');
+ $curlResultW = \Mockery::mock(CurlResult::class);
$curlResultW
->shouldReceive('getReturnCode')
->andReturn('204');
// Mocking the CURL Request
- $networkMock = \Mockery::mock('alias:Friendica\Util\Network');
+ $networkMock = \Mockery::mock('alias:' . Network::class);
$networkMock
->shouldReceive('fetchUrlFull')
->with('https://test/install/testrewrite')
// Mocking that we can use CURL
$this->setFunctions(['curl_init' => true]);
- // needed because of "normalise_link"
- require_once __DIR__ . '/../../../include/text.php';
-
$install = new Installer();
$this->assertTrue($install->checkHtAccess('https://test'));
/**
* @small
+ * @runInSeparateProcess
+ * @preserveGlobalState disabled
*/
public function testImagick()
{
- $imageMock = \Mockery::mock('alias:Friendica\Object\Image');
- $imageMock
- ->shouldReceive('supportedTypes')
- ->andReturn(['image/gif' => 'gif']);
+ $this->markTestIncomplete('needs adapted class_exists() mock');
+
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$this->setClasses(['Imagick' => true]);
$this->assertTrue($install->checkImagick());
$this->assertCheckExist(1,
- L10n::t('ImageMagick supports GIF'),
+ $this->l10nMock->t('ImageMagick supports GIF'),
'',
true,
false,
/**
* @small
+ * @runInSeparateProcess
+ * @preserveGlobalState disabled
*/
public function testImagickNotFound()
{
- $imageMock = \Mockery::mock('alias:Friendica\Object\Image');
- $imageMock
- ->shouldReceive('supportedTypes')
- ->andReturn([]);
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$this->setClasses(['Imagick' => true]);
// even there is no supported type, Imagick should return true (because it is not required)
$this->assertTrue($install->checkImagick());
$this->assertCheckExist(1,
- L10n::t('ImageMagick supports GIF'),
+ $this->l10nMock->t('ImageMagick supports GIF'),
'',
false,
false,
false,
$install->getChecks());
}
+
+ /**
+ * Test the setup of the config cache for installation
+ */
+ public function testSetUpCache()
+ {
+ $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
+
+ $install = new Installer();
+ $configCache = \Mockery::mock(Cache::class);
+ $configCache->shouldReceive('set')->with('config', 'php_path', \Mockery::any())->once();
+ $configCache->shouldReceive('set')->with('system', 'basepath', '/test/')->once();
+
+ $install->setUpCache($configCache, '/test/');
+ }
}
/**