You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

session.php 10KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. <?php
  2. /**
  3. * Copyright (c) 2013 Robin Appelman <icewind@owncloud.com>
  4. * This file is licensed under the Affero General Public License version 3 or
  5. * later.
  6. * See the COPYING-README file.
  7. */
  8. namespace Test\User;
  9. use OC\Session\Memory;
  10. use OC\User\User;
  11. class Session extends \Test\TestCase {
  12. public function testGetUser() {
  13. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  14. $session->expects($this->once())
  15. ->method('get')
  16. ->with('user_id')
  17. ->will($this->returnValue('foo'));
  18. $backend = $this->getMock('OC_User_Dummy');
  19. $backend->expects($this->once())
  20. ->method('userExists')
  21. ->with('foo')
  22. ->will($this->returnValue(true));
  23. $manager = new \OC\User\Manager();
  24. $manager->registerBackend($backend);
  25. $userSession = new \OC\User\Session($manager, $session);
  26. $user = $userSession->getUser();
  27. $this->assertEquals('foo', $user->getUID());
  28. }
  29. public function testSetUser() {
  30. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  31. $session->expects($this->once())
  32. ->method('set')
  33. ->with('user_id', 'foo');
  34. $manager = $this->getMock('\OC\User\Manager');
  35. $backend = $this->getMock('OC_User_Dummy');
  36. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  37. $user->expects($this->once())
  38. ->method('getUID')
  39. ->will($this->returnValue('foo'));
  40. $userSession = new \OC\User\Session($manager, $session);
  41. $userSession->setUser($user);
  42. }
  43. public function testLoginValidPasswordEnabled() {
  44. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  45. $session->expects($this->exactly(2))
  46. ->method('set')
  47. ->with($this->callback(function ($key) {
  48. switch ($key) {
  49. case 'user_id':
  50. case 'loginname':
  51. return true;
  52. break;
  53. default:
  54. return false;
  55. break;
  56. }
  57. },
  58. 'foo'));
  59. $managerMethods = get_class_methods('\OC\User\Manager');
  60. //keep following methods intact in order to ensure hooks are
  61. //working
  62. $doNotMock = array('__construct', 'emit', 'listen');
  63. foreach ($doNotMock as $methodName) {
  64. $i = array_search($methodName, $managerMethods, true);
  65. if ($i !== false) {
  66. unset($managerMethods[$i]);
  67. }
  68. }
  69. $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
  70. $backend = $this->getMock('OC_User_Dummy');
  71. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  72. $user->expects($this->once())
  73. ->method('isEnabled')
  74. ->will($this->returnValue(true));
  75. $user->expects($this->any())
  76. ->method('getUID')
  77. ->will($this->returnValue('foo'));
  78. $user->expects($this->once())
  79. ->method('updateLastLoginTimestamp');
  80. $manager->expects($this->once())
  81. ->method('checkPassword')
  82. ->with('foo', 'bar')
  83. ->will($this->returnValue($user));
  84. $userSession = new \OC\User\Session($manager, $session);
  85. $userSession->login('foo', 'bar');
  86. $this->assertEquals($user, $userSession->getUser());
  87. }
  88. public function testLoginValidPasswordDisabled() {
  89. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  90. $session->expects($this->never())
  91. ->method('set');
  92. $managerMethods = get_class_methods('\OC\User\Manager');
  93. //keep following methods intact in order to ensure hooks are
  94. //working
  95. $doNotMock = array('__construct', 'emit', 'listen');
  96. foreach ($doNotMock as $methodName) {
  97. $i = array_search($methodName, $managerMethods, true);
  98. if ($i !== false) {
  99. unset($managerMethods[$i]);
  100. }
  101. }
  102. $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
  103. $backend = $this->getMock('OC_User_Dummy');
  104. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  105. $user->expects($this->once())
  106. ->method('isEnabled')
  107. ->will($this->returnValue(false));
  108. $user->expects($this->never())
  109. ->method('updateLastLoginTimestamp');
  110. $manager->expects($this->once())
  111. ->method('checkPassword')
  112. ->with('foo', 'bar')
  113. ->will($this->returnValue($user));
  114. $userSession = new \OC\User\Session($manager, $session);
  115. $userSession->login('foo', 'bar');
  116. }
  117. public function testLoginInValidPassword() {
  118. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  119. $session->expects($this->never())
  120. ->method('set');
  121. $managerMethods = get_class_methods('\OC\User\Manager');
  122. //keep following methods intact in order to ensure hooks are
  123. //working
  124. $doNotMock = array('__construct', 'emit', 'listen');
  125. foreach ($doNotMock as $methodName) {
  126. $i = array_search($methodName, $managerMethods, true);
  127. if ($i !== false) {
  128. unset($managerMethods[$i]);
  129. }
  130. }
  131. $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
  132. $backend = $this->getMock('OC_User_Dummy');
  133. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  134. $user->expects($this->never())
  135. ->method('isEnabled');
  136. $user->expects($this->never())
  137. ->method('updateLastLoginTimestamp');
  138. $manager->expects($this->once())
  139. ->method('checkPassword')
  140. ->with('foo', 'bar')
  141. ->will($this->returnValue(false));
  142. $userSession = new \OC\User\Session($manager, $session);
  143. $userSession->login('foo', 'bar');
  144. }
  145. public function testLoginNonExisting() {
  146. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  147. $session->expects($this->never())
  148. ->method('set');
  149. $manager = $this->getMock('\OC\User\Manager');
  150. $backend = $this->getMock('OC_User_Dummy');
  151. $manager->expects($this->once())
  152. ->method('checkPassword')
  153. ->with('foo', 'bar')
  154. ->will($this->returnValue(false));
  155. $userSession = new \OC\User\Session($manager, $session);
  156. $userSession->login('foo', 'bar');
  157. }
  158. public function testRememberLoginValidToken() {
  159. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  160. $session->expects($this->exactly(1))
  161. ->method('set')
  162. ->with($this->callback(function ($key) {
  163. switch ($key) {
  164. case 'user_id':
  165. return true;
  166. default:
  167. return false;
  168. }
  169. },
  170. 'foo'));
  171. $managerMethods = get_class_methods('\OC\User\Manager');
  172. //keep following methods intact in order to ensure hooks are
  173. //working
  174. $doNotMock = array('__construct', 'emit', 'listen');
  175. foreach ($doNotMock as $methodName) {
  176. $i = array_search($methodName, $managerMethods, true);
  177. if ($i !== false) {
  178. unset($managerMethods[$i]);
  179. }
  180. }
  181. $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
  182. $backend = $this->getMock('OC_User_Dummy');
  183. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  184. $user->expects($this->any())
  185. ->method('getUID')
  186. ->will($this->returnValue('foo'));
  187. $user->expects($this->once())
  188. ->method('updateLastLoginTimestamp');
  189. $manager->expects($this->once())
  190. ->method('get')
  191. ->with('foo')
  192. ->will($this->returnValue($user));
  193. //prepare login token
  194. $token = 'goodToken';
  195. \OC::$server->getConfig()->setUserValue('foo', 'login_token', $token, time());
  196. $userSession = $this->getMock(
  197. '\OC\User\Session',
  198. //override, otherwise tests will fail because of setcookie()
  199. array('setMagicInCookie'),
  200. //there are passed as parameters to the constructor
  201. array($manager, $session));
  202. $granted = $userSession->loginWithCookie('foo', $token);
  203. $this->assertSame($granted, true);
  204. }
  205. public function testRememberLoginInvalidToken() {
  206. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  207. $session->expects($this->never())
  208. ->method('set');
  209. $managerMethods = get_class_methods('\OC\User\Manager');
  210. //keep following methods intact in order to ensure hooks are
  211. //working
  212. $doNotMock = array('__construct', 'emit', 'listen');
  213. foreach ($doNotMock as $methodName) {
  214. $i = array_search($methodName, $managerMethods, true);
  215. if ($i !== false) {
  216. unset($managerMethods[$i]);
  217. }
  218. }
  219. $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
  220. $backend = $this->getMock('OC_User_Dummy');
  221. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  222. $user->expects($this->any())
  223. ->method('getUID')
  224. ->will($this->returnValue('foo'));
  225. $user->expects($this->never())
  226. ->method('updateLastLoginTimestamp');
  227. $manager->expects($this->once())
  228. ->method('get')
  229. ->with('foo')
  230. ->will($this->returnValue($user));
  231. //prepare login token
  232. $token = 'goodToken';
  233. \OC::$server->getConfig()->setUserValue('foo', 'login_token', $token, time());
  234. $userSession = new \OC\User\Session($manager, $session);
  235. $granted = $userSession->loginWithCookie('foo', 'badToken');
  236. $this->assertSame($granted, false);
  237. }
  238. public function testRememberLoginInvalidUser() {
  239. $session = $this->getMock('\OC\Session\Memory', array(), array(''));
  240. $session->expects($this->never())
  241. ->method('set');
  242. $managerMethods = get_class_methods('\OC\User\Manager');
  243. //keep following methods intact in order to ensure hooks are
  244. //working
  245. $doNotMock = array('__construct', 'emit', 'listen');
  246. foreach ($doNotMock as $methodName) {
  247. $i = array_search($methodName, $managerMethods, true);
  248. if ($i !== false) {
  249. unset($managerMethods[$i]);
  250. }
  251. }
  252. $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
  253. $backend = $this->getMock('OC_User_Dummy');
  254. $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
  255. $user->expects($this->never())
  256. ->method('getUID');
  257. $user->expects($this->never())
  258. ->method('updateLastLoginTimestamp');
  259. $manager->expects($this->once())
  260. ->method('get')
  261. ->with('foo')
  262. ->will($this->returnValue(null));
  263. //prepare login token
  264. $token = 'goodToken';
  265. \OC::$server->getConfig()->setUserValue('foo', 'login_token', $token, time());
  266. $userSession = new \OC\User\Session($manager, $session);
  267. $granted = $userSession->loginWithCookie('foo', $token);
  268. $this->assertSame($granted, false);
  269. }
  270. public function testActiveUserAfterSetSession() {
  271. $users = array(
  272. 'foo' => new User('foo', null),
  273. 'bar' => new User('bar', null)
  274. );
  275. $manager = $this->getMockBuilder('\OC\User\Manager')
  276. ->disableOriginalConstructor()
  277. ->getMock();
  278. $manager->expects($this->any())
  279. ->method('get')
  280. ->will($this->returnCallback(function ($uid) use ($users) {
  281. return $users[$uid];
  282. }));
  283. $session = new Memory('');
  284. $session->set('user_id', 'foo');
  285. $userSession = new \OC\User\Session($manager, $session);
  286. $this->assertEquals($users['foo'], $userSession->getUser());
  287. $session2 = new Memory('');
  288. $session2->set('user_id', 'bar');
  289. $userSession->setSession($session2);
  290. $this->assertEquals($users['bar'], $userSession->getUser());
  291. }
  292. }