]> git.mxchange.org Git - friendica.git/blobdiff - tests/src/Core/InstallerTest.php
Improved logging
[friendica.git] / tests / src / Core / InstallerTest.php
index bdb1d53c0b112d500b98feb17a9faf803a4ba698..376703a270bf333485e884f8cc05f092bacca03a 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
 namespace Friendica\Core;
 
 use Dice\Dice;
-use Friendica\Core\Config\Cache\Cache;
+use DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts;
+use Friendica\Core\Config\ValueObject\Cache;
 use Friendica\DI;
-use Friendica\Network\IHTTPResult;
-use Friendica\Network\IHTTPClient;
+use Friendica\Network\HTTPClient\Capability\ICanHandleHttpResponses;
+use Friendica\Network\HTTPClient\Capability\ICanSendHttpRequests;
 use Friendica\Test\MockedTest;
 use Friendica\Test\Util\VFSTrait;
 use Mockery;
@@ -35,6 +36,7 @@ use Mockery\MockInterface;
 class InstallerTest extends MockedTest
 {
        use VFSTrait;
+       use ArraySubsetAsserts;
 
        /**
         * @var L10n|MockInterface
@@ -61,7 +63,7 @@ class InstallerTest extends MockedTest
                           ->with(L10n::class)
                           ->andReturn($this->l10nMock);
 
-               DI::init($this->dice);
+               DI::init($this->dice, true);
        }
 
        public static function tearDownAfterClass(): void
@@ -102,6 +104,8 @@ class InstallerTest extends MockedTest
                $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);
+               $this->mockL10nT('GNU Multiple Precision PHP module', 1);
+               $this->mockL10nT('Error: GNU Multiple Precision PHP module required but not installed.', 1);
                $this->mockL10nT('Program execution functions', 1);
                $this->mockL10nT('Error: Program execution functions (proc_open) required but not enabled.', 1);
        }
@@ -274,6 +278,17 @@ class InstallerTest extends MockedTest
                        true,
                        $install->getChecks());
 
+               $this->mockFunctionL10TCalls();
+               $this->setFunctions(['gmp_strval' => false]);
+               $install = new Installer();
+               self::assertFalse($install->checkFunctions());
+               self::assertCheckExist(12,
+                       'GNU Multiple Precision PHP module',
+                       'Error: GNU Multiple Precision PHP module required but not installed.',
+               false,
+                       true,
+                       $install->getChecks());
+
                $this->mockFunctionL10TCalls();
                $this->setFunctions([
                        'curl_init' => true,
@@ -284,6 +299,7 @@ class InstallerTest extends MockedTest
                        'posix_kill' => true,
                        'json_encode' => true,
                        'finfo_open' => true,
+                       'gmp_strval' => true,
                ]);
                $install = new Installer();
                self::assertTrue($install->checkFunctions());
@@ -319,7 +335,7 @@ class InstallerTest extends MockedTest
                $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
 
                // Mocking the CURL Response
-               $IHTTPResult = Mockery::mock(IHTTPResult::class);
+               $IHTTPResult = Mockery::mock(ICanHandleHttpResponses::class);
                $IHTTPResult
                        ->shouldReceive('getReturnCode')
                        ->andReturn('404');
@@ -331,7 +347,7 @@ class InstallerTest extends MockedTest
                        ->andReturn('test Error');
 
                // Mocking the CURL Request
-               $networkMock = Mockery::mock(IHTTPClient::class);
+               $networkMock = Mockery::mock(ICanSendHttpRequests::class);
                $networkMock
                        ->shouldReceive('fetchFull')
                        ->with('https://test/install/testrewrite')
@@ -342,10 +358,10 @@ class InstallerTest extends MockedTest
                        ->andReturn($IHTTPResult);
 
                $this->dice->shouldReceive('create')
-                    ->with(IHTTPClient::class)
+                    ->with(ICanSendHttpRequests::class)
                     ->andReturn($networkMock);
 
-               DI::init($this->dice);
+               DI::init($this->dice, true);
 
                // Mocking that we can use CURL
                $this->setFunctions(['curl_init' => true]);
@@ -366,19 +382,19 @@ class InstallerTest extends MockedTest
                $this->l10nMock->shouldReceive('t')->andReturnUsing(function ($args) { return $args; });
 
                // Mocking the failed CURL Response
-               $IHTTPResultF = Mockery::mock(IHTTPResult::class);
+               $IHTTPResultF = Mockery::mock(ICanHandleHttpResponses::class);
                $IHTTPResultF
                        ->shouldReceive('getReturnCode')
                        ->andReturn('404');
 
                // Mocking the working CURL Response
-               $IHTTPResultW = Mockery::mock(IHTTPResult::class);
+               $IHTTPResultW = Mockery::mock(ICanHandleHttpResponses::class);
                $IHTTPResultW
                        ->shouldReceive('getReturnCode')
                        ->andReturn('204');
 
                // Mocking the CURL Request
-               $networkMock = Mockery::mock(IHTTPClient::class);
+               $networkMock = Mockery::mock(ICanSendHttpRequests::class);
                $networkMock
                        ->shouldReceive('fetchFull')
                        ->with('https://test/install/testrewrite')
@@ -389,10 +405,10 @@ class InstallerTest extends MockedTest
                        ->andReturn($IHTTPResultW);
 
                $this->dice->shouldReceive('create')
-                          ->with(IHTTPClient::class)
+                          ->with(ICanSendHttpRequests::class)
                           ->andReturn($networkMock);
 
-               DI::init($this->dice);
+               DI::init($this->dice, true);
 
                // Mocking that we can use CURL
                $this->setFunctions(['curl_init' => true]);