<?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\BaseObject;
-use Friendica\Core\Config\Cache\ConfigCache;
+use Friendica\Core\Config\Cache;
+use Friendica\DI;
use Friendica\Network\CurlResult;
-use Friendica\Object\Image;
+use Friendica\Network\IHTTPRequest;
use Friendica\Test\MockedTest;
use Friendica\Test\Util\VFSTrait;
-use Friendica\Util\Network;
use Mockery\MockInterface;
class InstallerTest extends MockedTest
use VFSTrait;
/**
- * @var \Friendica\Core\L10n\L10n|MockInterface
+ * @var \Friendica\Core\L10n|MockInterface
*/
private $l10nMock;
+ /**
+ * @var Dice|MockInterface
+ */
+ private $dice;
public function setUp()
{
$this->setUpVfsDir();
- $this->l10nMock = \Mockery::mock(\Friendica\Core\L10n\L10n::class);
+ $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');
+ $this->dice = \Mockery::mock(Dice::class)->makePartial();
+ $this->dice = $this->dice->addRules(include __DIR__ . '/../../../static/dependencies.config.php');
- $dice->shouldReceive('create')
- ->with(\Friendica\Core\L10n\L10n::class)
+ $this->dice->shouldReceive('create')
+ ->with(\Friendica\Core\L10n::class)
->andReturn($this->l10nMock);
- BaseObject::setDependencyInjection($dice);
+ DI::init($this->dice);
}
private function mockL10nT(string $text, $times = null)
}
/**
- * Mocking the L10n::t() calls for the function checks
+ * Mocking the DI::l10n()->t() calls for the function checks
*/
private function mockFunctionL10TCalls()
{
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));
}
/**
->andReturn('test Error');
// Mocking the CURL Request
- $networkMock = \Mockery::mock('alias:' . Network::class);
+ $networkMock = \Mockery::mock(IHTTPRequest::class);
$networkMock
- ->shouldReceive('fetchUrlFull')
+ ->shouldReceive('fetchFull')
->with('https://test/install/testrewrite')
->andReturn($curlResult);
$networkMock
- ->shouldReceive('fetchUrlFull')
+ ->shouldReceive('fetchFull')
->with('http://test/install/testrewrite')
->andReturn($curlResult);
+ $this->dice->shouldReceive('create')
+ ->with(IHTTPRequest::class)
+ ->andReturn($networkMock);
+
+ DI::init($this->dice);
+
// Mocking that we can use CURL
$this->setFunctions(['curl_init' => true]);
->andReturn('204');
// Mocking the CURL Request
- $networkMock = \Mockery::mock('alias:' . Network::class);
+ $networkMock = \Mockery::mock(IHTTPRequest::class);
$networkMock
- ->shouldReceive('fetchUrlFull')
+ ->shouldReceive('fetchFull')
->with('https://test/install/testrewrite')
->andReturn($curlResultF);
$networkMock
- ->shouldReceive('fetchUrlFull')
+ ->shouldReceive('fetchFull')
->with('http://test/install/testrewrite')
->andReturn($curlResultW);
+ $this->dice->shouldReceive('create')
+ ->with(IHTTPRequest::class)
+ ->andReturn($networkMock);
+
+ DI::init($this->dice);
+
// Mocking that we can use CURL
$this->setFunctions(['curl_init' => true]);
*/
public function testImagick()
{
- $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
+ $this->markTestIncomplete('needs adapted class_exists() mock');
- $imageMock = \Mockery::mock('alias:'. Image::class);
- $imageMock
- ->shouldReceive('supportedTypes')
- ->andReturn(['image/gif' => 'gif']);
+ $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,
{
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
- $imageMock = \Mockery::mock('alias:' . Image::class);
- $imageMock
- ->shouldReceive('supportedTypes')
- ->andReturn([]);
-
$this->setClasses(['Imagick' => true]);
$install = new Installer();
// 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,
$this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
$install = new Installer();
- $configCache = \Mockery::mock(ConfigCache::class);
+ $configCache = \Mockery::mock(Cache::class);
$configCache->shouldReceive('set')->with('config', 'php_path', \Mockery::any())->once();
$configCache->shouldReceive('set')->with('system', 'basepath', '/test/')->once();