* @copyright 2005 Janrain, Inc. * @license http://www.gnu.org/copyleft/lesser.html LGPL */ require_once 'PHPUnit.php'; require_once 'Auth/OpenID/CryptUtil.php'; class Tests_Auth_OpenID_CryptUtil extends PHPUnit_TestCase { function test_length() { $cases = array(1, 10, 255); foreach ($cases as $length) { $data = Auth_OpenID_CryptUtil::getBytes($length); $this->assertEquals(strlen($data), $length); } } function test_different() { $num_iterations = 100; $data_length = 20; $data = Auth_OpenID_CryptUtil::getBytes($num_iterations); for ($i = 0; $i < $num_iterations; $i++) { $last = $data; $data = Auth_OpenID_CryptUtil::getBytes($data_length); $this->assertFalse($data == $last); } } function test_cryptrand() { // It's possible, but HIGHLY unlikely that a correct // implementation will fail by returning the same number twice $s = Auth_OpenID_CryptUtil::getBytes(32); $t = Auth_OpenID_CryptUtil::getBytes(32); $this->assertEquals(strlen($s), 32); $this->assertEquals(strlen($t), 32); $this->assertFalse($s == $t); } } ?>