]> git.mxchange.org Git - friendica.git/blobdiff - tests/Util/AppMockTrait.php
Rename *CacheDriver to *Cache because they don't act as driver anymore
[friendica.git] / tests / Util / AppMockTrait.php
index 817570dd58c948cd4418e3217e4a660f3d6d1ac2..f9b026979cbdef989567538d4585374e31ae8526 100644 (file)
@@ -2,6 +2,7 @@
 
 namespace Friendica\Test\Util;
 
+use Dice\Dice;
 use Friendica\App;
 use Friendica\BaseObject;
 use Friendica\Core\Config;
@@ -30,28 +31,90 @@ trait AppMockTrait
         */
        protected $profilerMock;
 
+       /**
+        * @var MockInterface|App\Mode The mocked App mode
+        */
+       protected $mode;
+
+       /**
+        * @var MockInterface|Dice The dependency injection library
+        */
+       protected $dice;
+
        /**
         * Mock the App
         *
         * @param vfsStreamDirectory $root The root directory
+        * @param bool $raw If true, no config mocking will be done
         */
-       public function mockApp($root)
+       public function mockApp(vfsStreamDirectory $root, $raw = false)
        {
-               $this->configMock = \Mockery::mock(Config\Cache\IConfigCache::class);
-               $configAdapterMock = \Mockery::mock(Config\Adapter\IConfigAdapter::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\ConfigCache::class);
+               $this->dice->shouldReceive('create')
+                          ->with(Config\Cache\ConfigCache::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
-               $configAdapterMock->shouldReceive('isConnected')->andReturn(false);
+               $configModel->shouldReceive('isConnected')->andReturn(false);
 
-               $config = new Config\Configuration($this->configMock, $configAdapterMock);
-               // Initialize empty Config
-               Config::init($config);
+               $config = new Config\JitConfiguration($this->configMock, $configModel);
+               $this->dice->shouldReceive('create')
+                          ->with(Config\Configuration::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());
+               $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::setDependencyInjection($this->dice);
+
+               if ($raw) {
+                       return;
+               }
+
                $this->configMock
                        ->shouldReceive('has')
                        ->andReturn(true);
@@ -79,26 +142,5 @@ trait AppMockTrait
                        ->shouldReceive('get')
                        ->with('system', 'theme')
                        ->andReturn('system_theme');
-
-               $this->profilerMock = \Mockery::mock(Profiler::class);
-               $this->profilerMock->shouldReceive('saveTimestamp');
-
-               $this->app
-                       ->shouldReceive('getConfigCache')
-                       ->andReturn($this->configMock);
-               $this->app
-                       ->shouldReceive('getTemplateEngine')
-                       ->andReturn(new FriendicaSmartyEngine());
-               $this->app
-                       ->shouldReceive('getCurrentTheme')
-                       ->andReturn('Smarty3');
-               $this->app
-                       ->shouldReceive('getBaseUrl')
-                       ->andReturn('http://friendica.local');
-               $this->app
-                       ->shouldReceive('getProfiler')
-                       ->andReturn($this->profilerMock);
-
-               BaseObject::setApp($this->app);
        }
 }