]> git.mxchange.org Git - friendica.git/blobdiff - tests/src/Util/CryptoTest.php
Merge remote-tracking branch 'upstream/develop' into inbox-gsid
[friendica.git] / tests / src / Util / CryptoTest.php
index 76e3076f0f3efe10d7dee6c61dcf3421ac94bfa3..82afc24832264f94a1f4c8e13cf3600749efc9a2 100644 (file)
@@ -1,12 +1,43 @@
 <?php
+/**
+ * @copyright Copyright (C) 2010-2023, the Friendica project
+ *
+ * @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 Crypto for mocking 'rand' and 'random_init'
+ */
 
-// this is in the same namespace as Crypto for mocking 'rand' and 'random_init'
+/// @todo Use right namespace - needs alternative way of mocking random_int()
 namespace Friendica\Util;
 
+use phpseclib\Crypt\RSA;
+use phpseclib\Math\BigInteger;
 use PHPUnit\Framework\TestCase;
 
 class CryptoTest extends TestCase
 {
+       public static function tearDownAfterClass(): void
+       {
+               // Reset mocking
+               global $phpMock;
+               $phpMock = [];
+
+               parent::tearDownAfterClass();
+       }
+
        /**
         * Replaces random_int results with given mocks
         *
@@ -14,24 +45,52 @@ class CryptoTest extends TestCase
        private function assertRandomInt($min, $max)
        {
                global $phpMock;
-               $phpMock['random_int'] = function($mMin, $mMax) use ($min, $max) {
-                       $this->assertEquals($min, $mMin);
-                       $this->assertEquals($max, $mMax);
+               $phpMock['random_int'] = function ($mMin, $mMax) use ($min, $max) {
+                       self::assertEquals($min, $mMin);
+                       self::assertEquals($max, $mMax);
                        return 1;
                };
        }
 
        public function testRandomDigitsRandomInt()
        {
-               $this->assertRandomInt(0, 9);
+               self::assertRandomInt(0, 9);
 
                $test = Crypto::randomDigits(1);
-               $this->assertEquals(1, strlen($test));
-               $this->assertEquals(1, $test);
+               self::assertEquals(1, strlen($test));
+               self::assertEquals(1, $test);
 
                $test = Crypto::randomDigits(8);
-               $this->assertEquals(8, strlen($test));
-               $this->assertEquals(11111111, $test);
+               self::assertEquals(8, strlen($test));
+               self::assertEquals(11111111, $test);
+       }
+
+       public function dataRsa(): array
+       {
+               return [
+                       'diaspora' => [
+                               'key' => file_get_contents(__DIR__ . '/../../datasets/crypto/rsa/diaspora-public-rsa-base64'),
+                               'expected' => file_get_contents(__DIR__ . '/../../datasets/crypto/rsa/diaspora-public-pem'),
+                       ],
+               ];
+       }
+
+       /**
+        * @dataProvider dataRsa
+        */
+       public function testPubRsaToMe(string $key, string $expected)
+       {
+               self::assertEquals($expected, Crypto::rsaToPem(base64_decode($key)));
+       }
+
+
+       public function dataPEM()
+       {
+               return [
+                       'diaspora' => [
+                               'key' => file_get_contents(__DIR__ . '/../../datasets/crypto/rsa/diaspora-public-pem'),
+                       ],
+               ];
        }
 }
 
@@ -44,7 +103,6 @@ function random_int($min, $max)
 {
        global $phpMock;
        if (isset($phpMock['random_int'])) {
-               $result = call_user_func_array($phpMock['random_int'], func_get_args());
-               return $result;
+               return call_user_func_array($phpMock['random_int'], func_get_args());
        }
 }