SessionManagerTest.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <?php
  2. require_once 'tests/utils/FakeConfigManager.php';
  3. // Initialize reference data _before_ PHPUnit starts a session
  4. require_once 'tests/utils/ReferenceSessionIdHashes.php';
  5. ReferenceSessionIdHashes::genAllHashes();
  6. use \Shaarli\SessionManager;
  7. use \PHPUnit\Framework\TestCase;
  8. /**
  9. * Test coverage for SessionManager
  10. */
  11. class SessionManagerTest extends TestCase
  12. {
  13. // Session ID hashes
  14. protected static $sidHashes = null;
  15. // Fake ConfigManager
  16. protected static $conf = null;
  17. /**
  18. * Assign reference data
  19. */
  20. public static function setUpBeforeClass()
  21. {
  22. self::$sidHashes = ReferenceSessionIdHashes::getHashes();
  23. self::$conf = new FakeConfigManager();
  24. }
  25. /**
  26. * Generate a session token
  27. */
  28. public function testGenerateToken()
  29. {
  30. $session = [];
  31. $sessionManager = new SessionManager($session, self::$conf);
  32. $token = $sessionManager->generateToken();
  33. $this->assertEquals(1, $session['tokens'][$token]);
  34. $this->assertEquals(40, strlen($token));
  35. }
  36. /**
  37. * Check a session token
  38. */
  39. public function testCheckToken()
  40. {
  41. $token = '4dccc3a45ad9d03e5542b90c37d8db6d10f2b38b';
  42. $session = [
  43. 'tokens' => [
  44. $token => 1,
  45. ],
  46. ];
  47. $sessionManager = new SessionManager($session, self::$conf);
  48. // check and destroy the token
  49. $this->assertTrue($sessionManager->checkToken($token));
  50. $this->assertFalse(isset($session['tokens'][$token]));
  51. // ensure the token has been destroyed
  52. $this->assertFalse($sessionManager->checkToken($token));
  53. }
  54. /**
  55. * Generate and check a session token
  56. */
  57. public function testGenerateAndCheckToken()
  58. {
  59. $session = [];
  60. $sessionManager = new SessionManager($session, self::$conf);
  61. $token = $sessionManager->generateToken();
  62. // ensure a token has been generated
  63. $this->assertEquals(1, $session['tokens'][$token]);
  64. $this->assertEquals(40, strlen($token));
  65. // check and destroy the token
  66. $this->assertTrue($sessionManager->checkToken($token));
  67. $this->assertFalse(isset($session['tokens'][$token]));
  68. // ensure the token has been destroyed
  69. $this->assertFalse($sessionManager->checkToken($token));
  70. }
  71. /**
  72. * Check an invalid session token
  73. */
  74. public function testCheckInvalidToken()
  75. {
  76. $session = [];
  77. $sessionManager = new SessionManager($session, self::$conf);
  78. $this->assertFalse($sessionManager->checkToken('4dccc3a45ad9d03e5542b90c37d8db6d10f2b38b'));
  79. }
  80. /**
  81. * Test SessionManager::checkId with a valid ID - TEST ALL THE HASHES!
  82. *
  83. * This tests extensively covers all hash algorithms / bit representations
  84. */
  85. public function testIsAnyHashSessionIdValid()
  86. {
  87. foreach (self::$sidHashes as $algo => $bpcs) {
  88. foreach ($bpcs as $bpc => $hash) {
  89. $this->assertTrue(SessionManager::checkId($hash));
  90. }
  91. }
  92. }
  93. /**
  94. * Test checkId with a valid ID - SHA-1 hashes
  95. */
  96. public function testIsSha1SessionIdValid()
  97. {
  98. $this->assertTrue(SessionManager::checkId(sha1('shaarli')));
  99. }
  100. /**
  101. * Test checkId with a valid ID - SHA-256 hashes
  102. */
  103. public function testIsSha256SessionIdValid()
  104. {
  105. $this->assertTrue(SessionManager::checkId(hash('sha256', 'shaarli')));
  106. }
  107. /**
  108. * Test checkId with a valid ID - SHA-512 hashes
  109. */
  110. public function testIsSha512SessionIdValid()
  111. {
  112. $this->assertTrue(SessionManager::checkId(hash('sha512', 'shaarli')));
  113. }
  114. /**
  115. * Test checkId with invalid IDs.
  116. */
  117. public function testIsSessionIdInvalid()
  118. {
  119. $this->assertFalse(SessionManager::checkId(''));
  120. $this->assertFalse(SessionManager::checkId([]));
  121. $this->assertFalse(
  122. SessionManager::checkId('c0ZqcWF3VFE2NmJBdm1HMVQ0ZHJ3UmZPbTFsNGhkNHI=')
  123. );
  124. }
  125. }