phpseclib/tests/Unit/Math/PrimeFieldTest.php

54 lines
1.4 KiB
PHP
Raw Normal View History

<?php
2023-06-04 11:12:11 -05:00
declare(strict_types=1);
namespace phpseclib3\Tests\Unit\Math;
use phpseclib3\Math\BigInteger;
use phpseclib3\Math\PrimeField;
use phpseclib3\Tests\PhpseclibTestCase;
class PrimeFieldTest extends PhpseclibTestCase
{
2023-03-31 03:43:58 -05:00
public function testPrimeFieldWithCompositeNumbers(): void
{
$this->expectException('UnexpectedValueException');
$a = new BigInteger('65', 10);
$p = new BigInteger('126', 10); // 126 isn't a prime
$num = new PrimeField($p);
$num2 = $num->newInteger($a);
2023-11-01 20:23:28 -05:00
$num2->squareRoot();
}
2023-11-01 20:26:03 -05:00
public function testPrimeFieldWithPrimeNumbers(): void
{
$a = new BigInteger('65', 10);
$p = new BigInteger('127', 10);
$num = new PrimeField($p);
$num2 = $num->newInteger($a);
2023-11-01 20:23:28 -05:00
$this->assertFalse($num2->squareRoot());
}
/**
* @group github1929
*/
2023-09-25 11:14:46 -05:00
public function testGarbageCollectedToBytes(): void
{
$blob = base64_decode('BFgsTFQeqKr0toyURbtT43INMDS7FTHjz3yn3MR1/Yv/pb2b9ZCYNQ/Tafe5hQpEJ4TpZOKfikP/hWZvFL8QCPgqbIGqw/KTfA==');
$public = "\0" . substr($blob, 0, 49);
$private = substr($blob, -24);
$point = \phpseclib3\Crypt\EC\Formats\Keys\PKCS1::extractPoint(
$public,
new \phpseclib3\Crypt\EC\Curves\secp192r1()
);
2023-07-26 21:54:02 -05:00
$this->assertIsString($point[0]->toBytes());
}
}