123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360 |
- <?php
-
- /**
- * Copyright (c) 2013 Robin Appelman <icewind@owncloud.com>
- * This file is licensed under the Affero General Public License version 3 or
- * later.
- * See the COPYING-README file.
- */
-
- namespace Test\User;
-
- use OC\Session\Memory;
- use OC\User\User;
-
- class Session extends \Test\TestCase {
- public function testGetUser() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->once())
- ->method('get')
- ->with('user_id')
- ->will($this->returnValue('foo'));
-
- $backend = $this->getMock('OC_User_Dummy');
- $backend->expects($this->once())
- ->method('userExists')
- ->with('foo')
- ->will($this->returnValue(true));
-
- $manager = new \OC\User\Manager();
- $manager->registerBackend($backend);
-
- $userSession = new \OC\User\Session($manager, $session);
- $user = $userSession->getUser();
- $this->assertEquals('foo', $user->getUID());
- }
-
- public function testSetUser() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->once())
- ->method('set')
- ->with('user_id', 'foo');
-
- $manager = $this->getMock('\OC\User\Manager');
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
- $user->expects($this->once())
- ->method('getUID')
- ->will($this->returnValue('foo'));
-
- $userSession = new \OC\User\Session($manager, $session);
- $userSession->setUser($user);
- }
-
- public function testLoginValidPasswordEnabled() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->exactly(2))
- ->method('set')
- ->with($this->callback(function ($key) {
- switch ($key) {
- case 'user_id':
- case 'loginname':
- return true;
- break;
- default:
- return false;
- break;
- }
- },
- 'foo'));
-
- $managerMethods = get_class_methods('\OC\User\Manager');
- //keep following methods intact in order to ensure hooks are
- //working
- $doNotMock = array('__construct', 'emit', 'listen');
- foreach ($doNotMock as $methodName) {
- $i = array_search($methodName, $managerMethods, true);
- if ($i !== false) {
- unset($managerMethods[$i]);
- }
- }
- $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
- $user->expects($this->once())
- ->method('isEnabled')
- ->will($this->returnValue(true));
- $user->expects($this->any())
- ->method('getUID')
- ->will($this->returnValue('foo'));
- $user->expects($this->once())
- ->method('updateLastLoginTimestamp');
-
- $manager->expects($this->once())
- ->method('checkPassword')
- ->with('foo', 'bar')
- ->will($this->returnValue($user));
-
- $userSession = new \OC\User\Session($manager, $session);
- $userSession->login('foo', 'bar');
- $this->assertEquals($user, $userSession->getUser());
- }
-
- public function testLoginValidPasswordDisabled() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->never())
- ->method('set');
-
- $managerMethods = get_class_methods('\OC\User\Manager');
- //keep following methods intact in order to ensure hooks are
- //working
- $doNotMock = array('__construct', 'emit', 'listen');
- foreach ($doNotMock as $methodName) {
- $i = array_search($methodName, $managerMethods, true);
- if ($i !== false) {
- unset($managerMethods[$i]);
- }
- }
- $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
- $user->expects($this->once())
- ->method('isEnabled')
- ->will($this->returnValue(false));
- $user->expects($this->never())
- ->method('updateLastLoginTimestamp');
-
- $manager->expects($this->once())
- ->method('checkPassword')
- ->with('foo', 'bar')
- ->will($this->returnValue($user));
-
- $userSession = new \OC\User\Session($manager, $session);
- $userSession->login('foo', 'bar');
- }
-
- public function testLoginInValidPassword() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->never())
- ->method('set');
-
- $managerMethods = get_class_methods('\OC\User\Manager');
- //keep following methods intact in order to ensure hooks are
- //working
- $doNotMock = array('__construct', 'emit', 'listen');
- foreach ($doNotMock as $methodName) {
- $i = array_search($methodName, $managerMethods, true);
- if ($i !== false) {
- unset($managerMethods[$i]);
- }
- }
- $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
- $user->expects($this->never())
- ->method('isEnabled');
- $user->expects($this->never())
- ->method('updateLastLoginTimestamp');
-
- $manager->expects($this->once())
- ->method('checkPassword')
- ->with('foo', 'bar')
- ->will($this->returnValue(false));
-
- $userSession = new \OC\User\Session($manager, $session);
- $userSession->login('foo', 'bar');
- }
-
- public function testLoginNonExisting() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->never())
- ->method('set');
-
- $manager = $this->getMock('\OC\User\Manager');
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $manager->expects($this->once())
- ->method('checkPassword')
- ->with('foo', 'bar')
- ->will($this->returnValue(false));
-
- $userSession = new \OC\User\Session($manager, $session);
- $userSession->login('foo', 'bar');
- }
-
- public function testRememberLoginValidToken() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->exactly(1))
- ->method('set')
- ->with($this->callback(function ($key) {
- switch ($key) {
- case 'user_id':
- return true;
- default:
- return false;
- }
- },
- 'foo'));
-
- $managerMethods = get_class_methods('\OC\User\Manager');
- //keep following methods intact in order to ensure hooks are
- //working
- $doNotMock = array('__construct', 'emit', 'listen');
- foreach ($doNotMock as $methodName) {
- $i = array_search($methodName, $managerMethods, true);
- if ($i !== false) {
- unset($managerMethods[$i]);
- }
- }
- $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
-
- $user->expects($this->any())
- ->method('getUID')
- ->will($this->returnValue('foo'));
- $user->expects($this->once())
- ->method('updateLastLoginTimestamp');
-
- $manager->expects($this->once())
- ->method('get')
- ->with('foo')
- ->will($this->returnValue($user));
-
- //prepare login token
- $token = 'goodToken';
- \OC::$server->getConfig()->setUserValue('foo', 'login_token', $token, time());
-
- $userSession = $this->getMock(
- '\OC\User\Session',
- //override, otherwise tests will fail because of setcookie()
- array('setMagicInCookie'),
- //there are passed as parameters to the constructor
- array($manager, $session));
-
- $granted = $userSession->loginWithCookie('foo', $token);
-
- $this->assertSame($granted, true);
- }
-
- public function testRememberLoginInvalidToken() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->never())
- ->method('set');
-
- $managerMethods = get_class_methods('\OC\User\Manager');
- //keep following methods intact in order to ensure hooks are
- //working
- $doNotMock = array('__construct', 'emit', 'listen');
- foreach ($doNotMock as $methodName) {
- $i = array_search($methodName, $managerMethods, true);
- if ($i !== false) {
- unset($managerMethods[$i]);
- }
- }
- $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
-
- $user->expects($this->any())
- ->method('getUID')
- ->will($this->returnValue('foo'));
- $user->expects($this->never())
- ->method('updateLastLoginTimestamp');
-
- $manager->expects($this->once())
- ->method('get')
- ->with('foo')
- ->will($this->returnValue($user));
-
- //prepare login token
- $token = 'goodToken';
- \OC::$server->getConfig()->setUserValue('foo', 'login_token', $token, time());
-
- $userSession = new \OC\User\Session($manager, $session);
- $granted = $userSession->loginWithCookie('foo', 'badToken');
-
- $this->assertSame($granted, false);
- }
-
- public function testRememberLoginInvalidUser() {
- $session = $this->getMock('\OC\Session\Memory', array(), array(''));
- $session->expects($this->never())
- ->method('set');
-
- $managerMethods = get_class_methods('\OC\User\Manager');
- //keep following methods intact in order to ensure hooks are
- //working
- $doNotMock = array('__construct', 'emit', 'listen');
- foreach ($doNotMock as $methodName) {
- $i = array_search($methodName, $managerMethods, true);
- if ($i !== false) {
- unset($managerMethods[$i]);
- }
- }
- $manager = $this->getMock('\OC\User\Manager', $managerMethods, array());
-
- $backend = $this->getMock('OC_User_Dummy');
-
- $user = $this->getMock('\OC\User\User', array(), array('foo', $backend));
-
- $user->expects($this->never())
- ->method('getUID');
- $user->expects($this->never())
- ->method('updateLastLoginTimestamp');
-
- $manager->expects($this->once())
- ->method('get')
- ->with('foo')
- ->will($this->returnValue(null));
-
- //prepare login token
- $token = 'goodToken';
- \OC::$server->getConfig()->setUserValue('foo', 'login_token', $token, time());
-
- $userSession = new \OC\User\Session($manager, $session);
- $granted = $userSession->loginWithCookie('foo', $token);
-
- $this->assertSame($granted, false);
- }
-
- public function testActiveUserAfterSetSession() {
- $users = array(
- 'foo' => new User('foo', null),
- 'bar' => new User('bar', null)
- );
-
- $manager = $this->getMockBuilder('\OC\User\Manager')
- ->disableOriginalConstructor()
- ->getMock();
-
- $manager->expects($this->any())
- ->method('get')
- ->will($this->returnCallback(function ($uid) use ($users) {
- return $users[$uid];
- }));
-
- $session = new Memory('');
- $session->set('user_id', 'foo');
- $userSession = new \OC\User\Session($manager, $session);
- $this->assertEquals($users['foo'], $userSession->getUser());
-
- $session2 = new Memory('');
- $session2->set('user_id', 'bar');
- $userSession->setSession($session2);
- $this->assertEquals($users['bar'], $userSession->getUser());
- }
- }
|