245 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			245 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
|   | <?php | ||
|  | 
 | ||
|  | require_once "Auth/OpenID/PAPE.php"; | ||
|  | require_once "Auth/OpenID/Message.php"; | ||
|  | require_once "Auth/OpenID/Server.php"; | ||
|  | 
 | ||
|  | class PapeRequestTestCase extends PHPUnit_Framework_TestCase { | ||
|  |     function setUp() | ||
|  |     { | ||
|  |         $this->req = new Auth_OpenID_PAPE_Request(); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_construct() | ||
|  |     { | ||
|  |       $this->assertEquals(array(), $this->req->preferred_auth_policies); | ||
|  |       $this->assertEquals(null, $this->req->max_auth_age); | ||
|  |       $this->assertEquals('pape', $this->req->ns_alias); | ||
|  | 
 | ||
|  |       $req2 = new Auth_OpenID_PAPE_Request(array(PAPE_AUTH_MULTI_FACTOR), 1000); | ||
|  |       $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $req2->preferred_auth_policies); | ||
|  |       $this->assertEquals(1000, $req2->max_auth_age); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_add_policy_uri() | ||
|  |     { | ||
|  |       $this->assertEquals(array(), $this->req->preferred_auth_policies); | ||
|  |       $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |       $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->preferred_auth_policies); | ||
|  |       $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |       $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->preferred_auth_policies); | ||
|  |       $this->req->addPolicyURI(PAPE_AUTH_PHISHING_RESISTANT); | ||
|  |       $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), | ||
|  |                           $this->req->preferred_auth_policies); | ||
|  |       $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |       $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), | ||
|  |                           $this->req->preferred_auth_policies); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_getExtensionArgs() { | ||
|  |       $this->assertEquals(array('preferred_auth_policies' => ''), $this->req->getExtensionArgs()); | ||
|  |       $this->req->addPolicyURI('http://uri'); | ||
|  |       $this->assertEquals(array('preferred_auth_policies' => 'http://uri'), $this->req->getExtensionArgs()); | ||
|  |       $this->req->addPolicyURI('http://zig'); | ||
|  |       $this->assertEquals(array('preferred_auth_policies' => 'http://uri http://zig'), $this->req->getExtensionArgs()); | ||
|  |       $this->req->max_auth_age = 789; | ||
|  |       $this->assertEquals(array('preferred_auth_policies' => 'http://uri http://zig', 'max_auth_age' => '789'), $this->req->getExtensionArgs()); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_parseExtensionArgs() { | ||
|  |       $args = array('preferred_auth_policies' => 'http://foo http://bar', | ||
|  |                     'max_auth_age' => '9'); | ||
|  |       $this->req->parseExtensionArgs($args); | ||
|  |       $this->assertEquals(9, $this->req->max_auth_age); | ||
|  |       $this->assertEquals(array('http://foo','http://bar'), $this->req->preferred_auth_policies); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_parseExtensionArgs_empty() { | ||
|  |       $this->req->parseExtensionArgs(array()); | ||
|  |       $this->assertEquals(null, $this->req->max_auth_age); | ||
|  |       $this->assertEquals(array(), $this->req->preferred_auth_policies); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_fromOpenIDRequest() { | ||
|  |       $openid_req_msg = Auth_OpenID_Message::fromOpenIDArgs(array( | ||
|  |           'mode' => 'checkid_setup', | ||
|  |           'ns' => Auth_OpenID_OPENID2_NS, | ||
|  |           'ns.pape' => Auth_OpenID_PAPE_NS_URI, | ||
|  |           'pape.preferred_auth_policies' => implode(' ', array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT)), | ||
|  |           'pape.max_auth_age' => '5476' | ||
|  |           )); | ||
|  |       $oid_req = new Auth_OpenID_Request(); | ||
|  |       $oid_req->message = $openid_req_msg; | ||
|  |       $req = Auth_OpenID_PAPE_Request::fromOpenIDRequest($oid_req); | ||
|  |       $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $req->preferred_auth_policies); | ||
|  |       $this->assertEquals(5476, $req->max_auth_age); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_fromOpenIDRequest_no_pape() { | ||
|  |       $message = new Auth_OpenID_Message(); | ||
|  |       $openid_req = new Auth_OpenID_Request(); | ||
|  |       $openid_req->message = $message; | ||
|  |       $pape_req = Auth_OpenID_PAPE_Request::fromOpenIDRequest($openid_req); | ||
|  |       $this->assertTrue($pape_req === null); | ||
|  |     } | ||
|  | 
 | ||
|  |     function test_preferred_types() { | ||
|  |         $this->req->addPolicyURI(PAPE_AUTH_PHISHING_RESISTANT); | ||
|  |         $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |         $pt = $this->req->preferredTypes(array(PAPE_AUTH_MULTI_FACTOR, | ||
|  |                                                PAPE_AUTH_MULTI_FACTOR_PHYSICAL)); | ||
|  |         $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $pt); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | class PAPE_DummySuccessResponse { | ||
|  |   function PAPE_DummySuccessResponse($message, $signed_stuff) | ||
|  |   { | ||
|  |     $this->message = $message; | ||
|  |     $this->signed_stuff = $signed_stuff; | ||
|  |   } | ||
|  | 
 | ||
|  |   function getSignedNS($ns_uri) | ||
|  |   { | ||
|  |     return $this->signed_stuff; | ||
|  |   } | ||
|  | } | ||
|  | 
 | ||
|  | class PapeResponseTestCase extends PHPUnit_Framework_TestCase { | ||
|  |   function setUp() { | ||
|  |     $this->req = new Auth_OpenID_PAPE_Response(); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_construct() { | ||
|  |     $this->assertEquals(array(), $this->req->auth_policies); | ||
|  |     $this->assertEquals(null, $this->req->auth_time); | ||
|  |     $this->assertEquals('pape', $this->req->ns_alias); | ||
|  |     $this->assertEquals(null, $this->req->nist_auth_level); | ||
|  | 
 | ||
|  |     $req2 = new Auth_OpenID_PAPE_Response(array(PAPE_AUTH_MULTI_FACTOR), | ||
|  |                                           '2001-01-01T04:05:23Z', | ||
|  |                                           3); | ||
|  |     $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $req2->auth_policies); | ||
|  |     $this->assertEquals('2001-01-01T04:05:23Z', $req2->auth_time); | ||
|  |     $this->assertEquals(3, $req2->nist_auth_level); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_add_policy_uri() { | ||
|  |     $this->assertEquals(array(), $this->req->auth_policies); | ||
|  |     $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |     $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->auth_policies); | ||
|  |     $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |     $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR), $this->req->auth_policies); | ||
|  |     $this->req->addPolicyURI(PAPE_AUTH_PHISHING_RESISTANT); | ||
|  |     $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $this->req->auth_policies); | ||
|  |     $this->req->addPolicyURI(PAPE_AUTH_MULTI_FACTOR); | ||
|  |     $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $this->req->auth_policies); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_getExtensionArgs() { | ||
|  |     $this->assertEquals(array('auth_policies' => 'none'), $this->req->getExtensionArgs()); | ||
|  |     $this->req->addPolicyURI('http://uri'); | ||
|  |     $this->assertEquals(array('auth_policies' => 'http://uri'), $this->req->getExtensionArgs()); | ||
|  |     $this->req->addPolicyURI('http://zig'); | ||
|  |     $this->assertEquals(array('auth_policies' => 'http://uri http://zig'), $this->req->getExtensionArgs()); | ||
|  |     $this->req->auth_time = '2008-03-02T12:34:56Z'; | ||
|  |     $this->assertEquals(array('auth_policies' => 'http://uri http://zig', 'auth_time' => '2008-03-02T12:34:56Z'), $this->req->getExtensionArgs()); | ||
|  |     $this->req->nist_auth_level = 3; | ||
|  |     $this->assertEquals(array('auth_policies' => 'http://uri http://zig', 'auth_time' => '2008-03-02T12:34:56Z', 'nist_auth_level' => '3'), $this->req->getExtensionArgs()); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_getExtensionArgs_error_auth_age() { | ||
|  |     $this->req->auth_time = "foo2008-03-02T12:34:56Z"; | ||
|  |     $this->assertEquals(false, $this->req->getExtensionArgs()); | ||
|  |     $this->req->auth_time = "2008-03-02T12:34:56Zbar"; | ||
|  |     $this->assertEquals(false, $this->req->getExtensionArgs()); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_getExtensionArgs_error_nist_auth_level() { | ||
|  |     $this->req->nist_auth_level = "high as a kite"; | ||
|  |     $this->assertEquals(false, $this->req->getExtensionArgs()); | ||
|  |     $this->req->nist_auth_level = 5; | ||
|  |     $this->assertEquals(false, $this->req->getExtensionArgs()); | ||
|  |     $this->req->nist_auth_level = -1; | ||
|  |     $this->assertEquals(false, $this->req->getExtensionArgs()); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_parseExtensionArgs() { | ||
|  |     $args = array('auth_policies' => 'http://foo http://bar', | ||
|  |                   'auth_time' => '2008-03-02T12:34:56Z'); | ||
|  |     $this->req->parseExtensionArgs($args); | ||
|  |     $this->assertEquals('2008-03-02T12:34:56Z', $this->req->auth_time); | ||
|  |     $this->assertEquals(array('http://foo','http://bar'), $this->req->auth_policies); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_parseExtensionArgs_empty() { | ||
|  |     $this->req->parseExtensionArgs(array()); | ||
|  |     $this->assertEquals(null, $this->req->auth_time); | ||
|  |     $this->assertEquals(array(), $this->req->auth_policies); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_parseExtensionArgs_strict_bogus1() { | ||
|  |     $args = array('auth_policies' => 'http://foo http://bar', | ||
|  |                   'auth_time' => 'yesterday'); | ||
|  |     $this->assertEquals(false, $this->req->parseExtensionArgs($args, true)); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_parseExtensionArgs_strict_bogus2() { | ||
|  |     $args = array('auth_policies' => 'http://foo http://bar', | ||
|  |                   'auth_time' => '63', | ||
|  |                   'nist_auth_level' => 'some'); | ||
|  |     $this->assertEquals(false, $this->req->parseExtensionArgs($args, true)); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_parseExtensionArgs_strict_good() { | ||
|  |     $args = array('auth_policies' => 'http://foo http://bar', | ||
|  |                   'auth_time' => '2008-03-02T12:34:56Z', | ||
|  |                   'nist_auth_level' => '0'); | ||
|  |     $this->req->parseExtensionArgs($args, true); | ||
|  |     $this->assertEquals(array('http://foo','http://bar'), $this->req->auth_policies); | ||
|  |     $this->assertEquals('2008-03-02T12:34:56Z', $this->req->auth_time); | ||
|  |     $this->assertEquals(0, $this->req->nist_auth_level); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_parseExtensionArgs_nostrict_bogus() { | ||
|  |     $args = array('auth_policies' => 'http://foo http://bar', | ||
|  |                   'auth_time' => 'the other day', | ||
|  |                   'nist_auth_level' => 'some'); | ||
|  |     $this->req->parseExtensionArgs($args); | ||
|  |     $this->assertEquals(array('http://foo','http://bar'), $this->req->auth_policies); | ||
|  |     $this->assertEquals(null, $this->req->auth_time); | ||
|  |     $this->assertEquals(null, $this->req->nist_auth_level); | ||
|  |   } | ||
|  | 
 | ||
|  |   function test_fromSuccessResponse() { | ||
|  |     $openid_req_msg = Auth_OpenID_Message::fromOpenIDArgs(array( | ||
|  |           'mode' => 'id_res', | ||
|  |           'ns' => Auth_OpenID_OPENID2_NS, | ||
|  |           'ns.pape' => Auth_OpenID_PAPE_NS_URI, | ||
|  |           'auth_policies' => implode(' ', array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT)), | ||
|  |           'auth_time' => '2008-03-02T12:34:56Z' | ||
|  |           )); | ||
|  |     $signed_stuff = array( | ||
|  |           'auth_policies' => implode(' ', array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT)), | ||
|  |           'auth_time' => '2008-03-02T12:34:56Z' | ||
|  |         ); | ||
|  |     $oid_req = new PAPE_DummySuccessResponse($openid_req_msg, $signed_stuff); | ||
|  |     $req = Auth_OpenID_PAPE_Response::fromSuccessResponse($oid_req); | ||
|  |     $this->assertEquals(array(PAPE_AUTH_MULTI_FACTOR, PAPE_AUTH_PHISHING_RESISTANT), $req->auth_policies); | ||
|  |     $this->assertEquals('2008-03-02T12:34:56Z', $req->auth_time); | ||
|  |   } | ||
|  | } | ||
|  | 
 | ||
|  | class Tests_Auth_OpenID_PAPE extends PHPUnit_Framework_TestSuite { | ||
|  |   function getName() { | ||
|  |     return "Tests_Auth_OpenID_PAPE"; | ||
|  |   } | ||
|  | 
 | ||
|  |   function Tests_Auth_OpenID_PAPE() { | ||
|  |     $this->addTestSuite('PapeRequestTestCase'); | ||
|  |     $this->addTestSuite('PapeResponseTestCase'); | ||
|  |   } | ||
|  | } | ||
|  | 
 | ||
|  | 
 |