AccessTest.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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_Oauth
  17. * @subpackage UnitTests
  18. * @copyright Copyright (c) 2005-2012 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. require_once 'Zend/Oauth/Token/Access.php';
  23. require_once 'Zend/Oauth/Config.php';
  24. /**
  25. * @category Zend
  26. * @package Zend_Oauth
  27. * @subpackage UnitTests
  28. * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
  29. * @license http://framework.zend.com/license/new-bsd New BSD License
  30. * @group Zend_Oauth
  31. * @group Zend_Oauth_Token
  32. */
  33. class Zend_Oauth_Token_AccessTest extends PHPUnit_Framework_TestCase
  34. {
  35. public function testConstructorSetsResponseObject()
  36. {
  37. $response = new Zend_Http_Response(200, array());
  38. $token = new Zend_Oauth_Token_Access($response);
  39. $this->assertTrue($token->getResponse() instanceof Zend_Http_Response);
  40. }
  41. public function testConstructorParsesRequestTokenFromResponseBody()
  42. {
  43. $body = 'oauth_token=jZaee4GF52O3lUb9&oauth_token_secret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri';
  44. $response = new Zend_Http_Response(200, array(), $body);
  45. $token = new Zend_Oauth_Token_Access($response);
  46. $this->assertEquals('jZaee4GF52O3lUb9', $token->getToken());
  47. }
  48. public function testConstructorParsesRequestTokenSecretFromResponseBody()
  49. {
  50. $body = 'oauth_token=jZaee4GF52O3lUb9&oauth_token_secret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri';
  51. $response = new Zend_Http_Response(200, array(), $body);
  52. $token = new Zend_Oauth_Token_Access($response);
  53. $this->assertEquals('J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri', $token->getTokenSecret());
  54. }
  55. public function testPropertyAccessWorks()
  56. {
  57. $body = 'oauth_token=jZaee4GF52O3lUb9&oauth_token_secret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri&foo=bar';
  58. $response = new Zend_Http_Response(200, array(), $body);
  59. $token = new Zend_Oauth_Token_Access($response);
  60. $this->assertEquals('J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri', $token->oauth_token_secret);
  61. }
  62. public function testTokenCastsToEncodedResponseBody()
  63. {
  64. $body = 'oauth_token=jZaee4GF52O3lUb9&oauth_token_secret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri';
  65. $token = new Zend_Oauth_Token_Access();
  66. $token->setToken('jZaee4GF52O3lUb9');
  67. $token->setTokenSecret('J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri');
  68. $this->assertEquals($body, (string) $token);
  69. }
  70. public function testToStringReturnsEncodedResponseBody()
  71. {
  72. $body = 'oauth_token=jZaee4GF52O3lUb9&oauth_token_secret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri';
  73. $token = new Zend_Oauth_Token_Access();
  74. $token->setToken('jZaee4GF52O3lUb9');
  75. $token->setTokenSecret('J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri');
  76. $this->assertEquals($body, $token->toString());
  77. }
  78. public function testIsValidDetectsBadResponse()
  79. {
  80. $body = 'oauthtoken=jZaee4GF52O3lUb9&oauthtokensecret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri';
  81. $response = new Zend_Http_Response(200, array(), $body);
  82. $token = new Zend_Oauth_Token_Access($response);
  83. $this->assertFalse($token->isValid());
  84. }
  85. public function testIsValidDetectsGoodResponse()
  86. {
  87. $body = 'oauth_token=jZaee4GF52O3lUb9&oauth_token_secret=J4Ms4n8sxjYc0A8K0KOQFCTL0EwUQTri';
  88. $response = new Zend_Http_Response(200, array(), $body);
  89. $token = new Zend_Oauth_Token_Access($response);
  90. $this->assertTrue($token->isValid());
  91. }
  92. public function testToHeaderReturnsValidHeaderString()
  93. {
  94. $token = new Zend_Oauth_Token_Access(null, new Test_Http_Utility_90244);
  95. $value = $token->toHeader(
  96. 'http://www.example.com',
  97. new Test_Config_90244
  98. );
  99. $this->assertEquals('OAuth realm="",oauth_consumer_key="1234567890",oauth_nonce="e807f1fcf82d132f9bb018ca6738a19f",oauth_signature_method="HMAC-SHA1",oauth_timestamp="12345678901",oauth_version="1.0",oauth_token="abcde",oauth_signature="6fb42da0e32e07b61c9f0251fe627a9c"', $value);
  100. }
  101. }
  102. class Test_Http_Utility_90244 extends Zend_Oauth_Http_Utility
  103. {
  104. public function __construct(){}
  105. public function generateNonce(){return md5('1234567890');}
  106. public function generateTimestamp(){return '12345678901';}
  107. public function sign(array $params, $signatureMethod, $consumerSecret,
  108. $accessTokenSecret = null, $method = null, $url = null)
  109. {
  110. return md5('0987654321');
  111. }
  112. }
  113. class Test_Config_90244 extends Zend_Oauth_Config
  114. {
  115. public function getConsumerKey(){return '1234567890';}
  116. public function getSignatureMethod(){return 'HMAC-SHA1';}
  117. public function getVersion(){return '1.0';}
  118. public function getRequestTokenUrl(){return 'http://www.example.com/request';}
  119. public function getToken(){$token = new Zend_Oauth_Token_Access;
  120. $token->setToken('abcde');
  121. return $token;}
  122. public function getRequestMethod()
  123. {return 'POST';}
  124. }