SregTest.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. <?php
  2. /**
  3. * Zend Framework
  4. *
  5. * LICENSE
  6. *
  7. * This source file is subject to the new BSD license that is bundled
  8. * with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://framework.zend.com/license/new-bsd
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@zend.com so we can send you a copy immediately.
  14. *
  15. * @category Zend
  16. * @package Zend_OpenId
  17. * @subpackage UnitTests
  18. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. * @version $Id$
  21. */
  22. /**
  23. * Zend_OpenId
  24. */
  25. require_once 'Zend/OpenId/Extension/Sreg.php';
  26. /**
  27. * PHPUnit test case
  28. */
  29. require_once 'PHPUnit/Framework.php';
  30. /**
  31. * @category Zend
  32. * @package Zend_OpenId
  33. * @subpackage UnitTests
  34. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  35. * @license http://framework.zend.com/license/new-bsd New BSD License
  36. * @group Zend_OpenId
  37. */
  38. class Zend_OpenId_Extension_SregTest extends PHPUnit_Framework_TestCase
  39. {
  40. const USER = "test_user";
  41. const EMAIL = "user@test.com";
  42. const POLICY = "http://www.somewhere.com/policy.html";
  43. /**
  44. * testing getProperties
  45. *
  46. */
  47. public function testGetProperties()
  48. {
  49. $ext = new Zend_OpenId_Extension_Sreg();
  50. $this->assertSame( array(), $ext->getProperties() );
  51. $ext = new Zend_OpenId_Extension_Sreg(array('nickname'=>true,'email'=>false));
  52. $this->assertSame( array('nickname'=>true,'email'=>false), $ext->getProperties() );
  53. }
  54. /**
  55. * testing getPolicyUrl
  56. *
  57. */
  58. public function testGetPolicyUrl()
  59. {
  60. $ext = new Zend_OpenId_Extension_Sreg();
  61. $this->assertSame( null, $ext->getPolicyUrl() );
  62. $ext = new Zend_OpenId_Extension_Sreg(null, self::POLICY);
  63. $this->assertSame( self::POLICY, $ext->getPolicyUrl() );
  64. }
  65. /**
  66. * testing getVersion
  67. *
  68. */
  69. public function testGetVersion()
  70. {
  71. $ext = new Zend_OpenId_Extension_Sreg();
  72. $this->assertSame( 1.0, $ext->getVersion() );
  73. $ext = new Zend_OpenId_Extension_Sreg(null, null, 1.1);
  74. $this->assertSame( 1.1, $ext->getVersion() );
  75. }
  76. /**
  77. * testing getSregProperties
  78. *
  79. */
  80. public function testGetSregProperties()
  81. {
  82. $this->assertSame(
  83. array(
  84. "nickname",
  85. "email",
  86. "fullname",
  87. "dob",
  88. "gender",
  89. "postcode",
  90. "country",
  91. "language",
  92. "timezone"
  93. ),
  94. Zend_OpenId_Extension_Sreg::getSregProperties() );
  95. }
  96. /**
  97. * testing prepareRequest
  98. *
  99. */
  100. public function testPrepareRequest()
  101. {
  102. $ext = new Zend_OpenId_Extension_Sreg();
  103. $params = array();
  104. $this->assertTrue( $ext->prepareRequest($params) );
  105. $this->assertSame( array(), $params );
  106. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>true,"email"=>false));
  107. $params = array();
  108. $this->assertTrue( $ext->prepareRequest($params) );
  109. $this->assertSame( array('openid.sreg.required'=>"nickname", 'openid.sreg.optional'=>"email"), $params );
  110. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>true,"email"=>true), self::POLICY);
  111. $params = array();
  112. $this->assertTrue( $ext->prepareRequest($params) );
  113. $this->assertSame( array('openid.sreg.required'=>"nickname,email", 'openid.sreg.policy_url' => self::POLICY), $params );
  114. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>false,"email"=>false), self::POLICY, 1.1);
  115. $params = array();
  116. $this->assertTrue( $ext->prepareRequest($params) );
  117. $this->assertSame( array('openid.ns.sreg'=>"http://openid.net/extensions/sreg/1.1",'openid.sreg.optional'=>"nickname,email", 'openid.sreg.policy_url' => self::POLICY), $params );
  118. }
  119. /**
  120. * testing parseRequest
  121. *
  122. */
  123. public function testParseRequest()
  124. {
  125. $ext = new Zend_OpenId_Extension_Sreg();
  126. $this->assertTrue( $ext->parseRequest(array()) );
  127. $this->assertSame( array(), $ext->getProperties() );
  128. $this->assertSame( null, $ext->getPolicyUrl() );
  129. $this->assertSame( 1.0, $ext->getVersion() );
  130. $this->assertTrue( $ext->parseRequest(array('openid_sreg_required'=>"nickname", 'openid_sreg_optional'=>"email")) );
  131. $this->assertSame( array('nickname'=>true,'email'=>false), $ext->getProperties() );
  132. $this->assertSame( null, $ext->getPolicyUrl() );
  133. $this->assertSame( 1.0, $ext->getVersion() );
  134. $this->assertTrue( $ext->parseRequest(array('openid_sreg_required'=>"nickname,email", 'openid_sreg_policy_url' => self::POLICY)) );
  135. $this->assertSame( array('nickname'=>true,'email'=>true), $ext->getProperties() );
  136. $this->assertSame( self::POLICY, $ext->getPolicyUrl() );
  137. $this->assertSame( 1.0, $ext->getVersion() );
  138. $this->assertTrue( $ext->parseRequest(array('openid_ns_sreg'=>"http://openid.net/extensions/sreg/1.1", 'openid_sreg_optional'=>"nickname,email", 'openid_sreg_policy_url' => self::POLICY)) );
  139. $this->assertSame( array('nickname'=>false,'email'=>false), $ext->getProperties() );
  140. $this->assertSame( self::POLICY, $ext->getPolicyUrl() );
  141. $this->assertSame( 1.1, $ext->getVersion() );
  142. }
  143. /**
  144. * testing getTrustData
  145. *
  146. */
  147. public function testGetTrustData()
  148. {
  149. $ext = new Zend_OpenId_Extension_Sreg();
  150. $data = array();
  151. $this->assertTrue( $ext->getTrustData($data) );
  152. $this->assertSame( 1, count($data) );
  153. $this->assertSame( array(), $data["Zend_OpenId_Extension_Sreg"] );
  154. $ext = new Zend_OpenId_Extension_Sreg(array('nickname'=>true,'email'=>false));
  155. $data = array();
  156. $this->assertTrue( $ext->getTrustData($data) );
  157. $this->assertSame( 1, count($data) );
  158. $this->assertSame( array('nickname'=>true,'email'=>false), $data["Zend_OpenId_Extension_Sreg"] );
  159. }
  160. /**
  161. * testing checkTrustData
  162. *
  163. */
  164. public function testCheckTrustData()
  165. {
  166. $ext = new Zend_OpenId_Extension_Sreg();
  167. $this->assertTrue( $ext->checkTrustData(array()) );
  168. $this->assertSame( array(), $ext->getProperties() );
  169. $ext = new Zend_OpenId_Extension_Sreg();
  170. $this->assertTrue( $ext->checkTrustData(array("Zend_OpenId_Extension_Sreg"=>array())) );
  171. $this->assertSame( array(), $ext->getProperties() );
  172. $ext = new Zend_OpenId_Extension_Sreg(array());
  173. $this->assertTrue( $ext->checkTrustData(array("Zend_OpenId_Extension_Sreg"=>array("nickname"=>self::USER, "email"=>self::EMAIL))) );
  174. $this->assertSame( array(), $ext->getProperties() );
  175. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>true,"email"=>true));
  176. $this->assertTrue( $ext->checkTrustData(array("Zend_OpenId_Extension_Sreg"=>array("nickname"=>self::USER, "email"=>self::EMAIL))) );
  177. $this->assertSame( array('nickname'=>self::USER, "email"=>self::EMAIL), $ext->getProperties() );
  178. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>true,"email"=>true));
  179. $this->assertFalse( $ext->checkTrustData(array("Zend_OpenId_Extension_Sreg"=>array("nickname"=>self::USER))) );
  180. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>true,"email"=>false));
  181. $this->assertTrue( $ext->checkTrustData(array("Zend_OpenId_Extension_Sreg"=>array("nickname"=>self::USER))) );
  182. $this->assertSame( array('nickname'=>self::USER), $ext->getProperties() );
  183. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>false,"email"=>true));
  184. $this->assertTrue( $ext->checkTrustData(array("Zend_OpenId_Extension_Sreg"=>array("nickname"=>self::USER, "email"=>self::EMAIL))) );
  185. $this->assertSame( array('nickname'=>self::USER, "email"=>self::EMAIL), $ext->getProperties() );
  186. $ext = new Zend_OpenId_Extension_Sreg(array("nickname"=>false,"email"=>true));
  187. $this->assertFalse( $ext->checkTrustData(array("Zend_OpenId_Extension_SregX"=>array("nickname"=>self::USER, "email"=>self::EMAIL))) );
  188. }
  189. /**
  190. * testing prepareResponse
  191. *
  192. */
  193. public function testPrepareResponse()
  194. {
  195. $ext = new Zend_OpenId_Extension_Sreg();
  196. $params = array();
  197. $this->assertTrue( $ext->prepareResponse($params) );
  198. $this->assertSame( array(), $params );
  199. $ext = new Zend_OpenId_Extension_Sreg(array('nickname'=>self::USER, "email"=>self::EMAIL), self::POLICY);
  200. $params = array();
  201. $this->assertTrue( $ext->prepareResponse($params) );
  202. $this->assertSame( array('openid.sreg.nickname'=>self::USER, 'openid.sreg.email'=>self::EMAIL), $params );
  203. $ext = new Zend_OpenId_Extension_Sreg(array('nickname'=>self::USER, "email"=>self::EMAIL), self::POLICY, 1.1);
  204. $params = array();
  205. $this->assertTrue( $ext->prepareResponse($params) );
  206. $this->assertSame( array('openid.ns.sreg'=>"http://openid.net/extensions/sreg/1.1", 'openid.sreg.nickname'=>self::USER, 'openid.sreg.email'=>self::EMAIL), $params );
  207. }
  208. /**
  209. * testing parseResponse
  210. *
  211. */
  212. public function testParseResponse()
  213. {
  214. $ext = new Zend_OpenId_Extension_Sreg();
  215. $this->assertTrue( $ext->parseResponse(array()) );
  216. $this->assertSame( array(), $ext->getProperties() );
  217. $this->assertSame( null, $ext->getPolicyUrl() );
  218. $this->assertSame( 1.0, $ext->getVersion() );
  219. $this->assertTrue( $ext->parseResponse(array('openid_sreg_nickname'=>self::USER, 'openid_sreg_email'=>self::EMAIL)) );
  220. $this->assertSame( array('nickname'=>self::USER,'email'=>self::EMAIL), $ext->getProperties() );
  221. $this->assertSame( null, $ext->getPolicyUrl() );
  222. $this->assertSame( 1.0, $ext->getVersion() );
  223. $this->assertTrue( $ext->parseResponse(array('openid_sreg_nickname'=>self::USER, 'openid_sreg_email'=>self::EMAIL, 'openid_sreg_policy_url' => self::POLICY)) );
  224. $this->assertSame( array('nickname'=>self::USER,'email'=>self::EMAIL), $ext->getProperties() );
  225. $this->assertSame( null, $ext->getPolicyUrl() );
  226. $this->assertSame( 1.0, $ext->getVersion() );
  227. $this->assertTrue( $ext->parseResponse(array('openid_ns_sreg'=>"http://openid.net/extensions/sreg/1.1",'openid_sreg_nickname'=>self::USER, 'openid_sreg_email'=>self::EMAIL)) );
  228. $this->assertSame( array('nickname'=>self::USER,'email'=>self::EMAIL), $ext->getProperties() );
  229. $this->assertSame( null, $ext->getPolicyUrl() );
  230. $this->assertSame( 1.1, $ext->getVersion() );
  231. }
  232. }