markTestSkipped('Extension bcmath not loaded'); } try { $math = new Zend_Crypt_Math_BigInteger(); } catch (Zend_Crypt_Math_BigInteger_Exception $e) { if (strpos($e->getMessage(), 'big integer precision math support not detected') !== false) { $this->markTestSkipped($e->getMessage()); } else { throw $e; } } $math = new Zend_Crypt_Math(); $higher = '155172898181473697471232257763715539915724801966915404479707795314057629378541917580651227423698188993727816152646631438561595825688188889951272158842675419950341258706556549803580104870537681476726513255747040765857479291291572334510643245094715007229621094194349783925984760375594985848253359305585439638443'; $lower = '155172898181473697471232257763715539915724801966915404479707795314057629378541917580651227423698188993727816152646631438561595825688188889951272158842675419950341258706556549803580104870537681476726513255747040765857479291291572334510643245094715007229621094194349783925984760375594985848253359305585439638442'; $result = $math->rand($lower, $higher); $this->assertTrue(bccomp($result, $higher) !== '1'); $this->assertTrue(bccomp($result, $lower) !== '-1'); } public function testRandBytes() { for ($length = 1; $length < 4096; $length++) { $rand = Zend_Crypt_Math::randBytes($length); $this->assertTrue(false !== $rand); $this->assertEquals($length, strlen($rand)); } } public function testRandInteger() { for ($i = 0; $i < 1024; $i++) { $min = rand(1, PHP_INT_MAX/2); $max = $min + rand(1, PHP_INT_MAX/2 - 1); $rand = Zend_Crypt_Math::randInteger($min, $max); $this->assertGreaterThanOrEqual($min, $rand); $this->assertLessThanOrEqual($max, $rand); } } public static function provideRandInt() { return [ [2, 1, 10000, 100, 0.9, 1.1, false], [2, 1, 10000, 100, 0.8, 1.2, true] ]; } /** * A Monte Carlo test that generates $cycles numbers from 0 to $tot * and test if the numbers are above or below the line y=x with a * frequency range of [$min, $max] * * @dataProvider provideRandInt */ public function testMontecarloRandInteger($num, $valid, $cycles, $tot, $min, $max, $strong) { try { $test = Zend_Crypt_Math::randBytes(1, $strong); } catch (Zend_Crypt_Exception $e) { $this->markTestSkipped($e->getMessage()); } $i = 0; $count = 0; do { $up = 0; $down = 0; for ($i = 0; $i < $cycles; $i++) { $x = Zend_Crypt_Math::randInteger(0, $tot, $strong); $y = Zend_Crypt_Math::randInteger(0, $tot, $strong); if ($x > $y) { $up++; } elseif ($x < $y) { $down++; } } $this->assertGreaterThan(0, $up); $this->assertGreaterThan(0, $down); $ratio = $up / $down; if ($ratio > $min && $ratio < $max) { $count++; } $i++; } while ($i < $num && $count < $valid); if ($count < $valid) { $this->fail('The random number generator failed the Monte Carlo test'); } } }