<?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/>.
+ *
+ */
namespace Friendica\Test\Util;
+use Dice\Dice;
use Friendica\App;
-use Friendica\BaseObject;
use Friendica\Core\Config;
+use Friendica\DI;
use Friendica\Render\FriendicaSmartyEngine;
use Friendica\Util\Profiler;
use Mockery\MockInterface;
protected $app;
/**
- * @var MockInterface|Config\Configuration The mocked Config Cache
+ * @var MockInterface|Config\IConfig The mocked Config Cache
*/
protected $configMock;
*/
protected $mode;
+ /**
+ * @var MockInterface|Dice The dependency injection library
+ */
+ protected $dice;
+
/**
* Mock the App
*
*/
public function mockApp(vfsStreamDirectory $root, $raw = false)
{
- $this->configMock = \Mockery::mock(Config\Cache\ConfigCache::class);
+ $this->dice = \Mockery::mock(Dice::class)->makePartial();
+ $this->dice = $this->dice->addRules(include __DIR__ . '/../../static/dependencies.config.php');
+
+ $this->configMock = \Mockery::mock(Config\Cache::class);
+ $this->dice->shouldReceive('create')
+ ->with(Config\Cache::class)
+ ->andReturn($this->configMock);
$this->mode = \Mockery::mock(App\Mode::class);
+ $this->dice->shouldReceive('create')
+ ->with(App\Mode::class)
+ ->andReturn($this->mode);
$configModel= \Mockery::mock(\Friendica\Model\Config\Config::class);
// Disable the adapter
$configModel->shouldReceive('isConnected')->andReturn(false);
- $config = new Config\JitConfiguration($this->configMock, $configModel);
- // Initialize empty Config
- Config::init($config);
+ $config = new Config\JitConfig($this->configMock, $configModel);
+ $this->dice->shouldReceive('create')
+ ->with(Config\IConfig::class)
+ ->andReturn($config);
// Mocking App and most used functions
$this->app = \Mockery::mock(App::class);
+ $this->dice->shouldReceive('create')
+ ->with(App::class)
+ ->andReturn($this->app);
$this->app
->shouldReceive('getBasePath')
->andReturn($root->url());
- $this->app
- ->shouldReceive('getMode')
- ->andReturn($this->mode);
-
$this->profilerMock = \Mockery::mock(Profiler::class);
$this->profilerMock->shouldReceive('saveTimestamp');
+ $this->dice->shouldReceive('create')
+ ->with(Profiler::class)
+ ->andReturn($this->profilerMock);
$this->app
->shouldReceive('getConfigCache')
->andReturn($this->configMock);
- $this->app
- ->shouldReceive('getConfig')
- ->andReturn($config);
$this->app
->shouldReceive('getTemplateEngine')
- ->andReturn(new FriendicaSmartyEngine());
+ ->andReturn(new FriendicaSmartyEngine('frio', []));
$this->app
->shouldReceive('getCurrentTheme')
->andReturn('Smarty3');
- $this->app
- ->shouldReceive('getProfiler')
- ->andReturn($this->profilerMock);
- $this->app
- ->shouldReceive('getBaseUrl')
- ->andReturnUsing(function () {
- return $this->configMock->get('system', 'url');
- });
- BaseObject::setApp($this->app);
+ DI::init($this->dice);
if ($raw) {
return;