phpOMS/tests/Math/Number/IntegerTest.php
2018-06-26 21:08:26 +02:00

57 lines
1.4 KiB
PHP

<?php
/**
* Orange Management
*
* PHP Version 7.2
*
* @package TBD
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link http://website.orange-management.de
*/
namespace phpOMS\tests\Math\Number;
use phpOMS\Math\Number\Integer;
class IntegerTest extends \PHPUnit\Framework\TestCase
{
public function testIsInteger()
{
self::assertTrue(Integer::isInteger(4));
self::assertFalse(Integer::isInteger(1.0));
self::assertFalse(Integer::isInteger('3'));
}
public function testFactorization()
{
self::assertArraySubset([2, 2, 5, 5], Integer::trialFactorization(100));
self::assertArraySubset([2], Integer::trialFactorization(2));
self::assertEquals([], Integer::trialFactorization(1));
}
public function testOther()
{
self::assertEquals(101, Integer::pollardsRho(10403, 2, 1, 2, 2));
self::assertEquals([59, 101], Integer::fermatFactor(5959));
}
/**
* @expectedException \Exception
*/
public function testInvalidFermatParameter()
{
Integer::fermatFactor(8);
}
public function testGCD()
{
self::assertEquals(4, Integer::greatestCommonDivisor(4, 4));
self::assertEquals(6, Integer::greatestCommonDivisor(54, 24));
self::assertEquals(6, Integer::greatestCommonDivisor(24, 54));
self::assertEquals(1, Integer::greatestCommonDivisor(7, 13));
}
}