123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace Test\User;
- use OC\AllConfig;
- use OC\User\Database;
- use OC\User\Manager;
- use OCP\EventDispatcher\IEventDispatcher;
- use OCP\ICache;
- use OCP\ICacheFactory;
- use OCP\IConfig;
- use OCP\IUser;
- use OCP\IUserManager;
- use Psr\Log\LoggerInterface;
- use Test\TestCase;
- /**
- * Class ManagerTest
- *
- * @group DB
- *
- * @package Test\User
- */
- class ManagerTest extends TestCase {
- /** @var IConfig */
- private $config;
- /** @var IEventDispatcher */
- private $eventDispatcher;
- /** @var ICacheFactory */
- private $cacheFactory;
- /** @var ICache */
- private $cache;
- /** @var LoggerInterface */
- private $logger;
- protected function setUp(): void {
- parent::setUp();
- $this->config = $this->createMock(IConfig::class);
- $this->eventDispatcher = $this->createMock(IEventDispatcher::class);
- $this->cacheFactory = $this->createMock(ICacheFactory::class);
- $this->cache = $this->createMock(ICache::class);
- $this->logger = $this->createMock(LoggerInterface::class);
- $this->cacheFactory->method('createDistributed')
- ->willReturn($this->cache);
- }
- public function testGetBackends() {
- $userDummyBackend = $this->createMock(\Test\Util\User\Dummy::class);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($userDummyBackend);
- $this->assertEquals([$userDummyBackend], $manager->getBackends());
- $dummyDatabaseBackend = $this->createMock(Database::class);
- $manager->registerBackend($dummyDatabaseBackend);
- $this->assertEquals([$userDummyBackend, $dummyDatabaseBackend], $manager->getBackends());
- }
- public function testUserExistsSingleBackendExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(true);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertTrue($manager->userExists('foo'));
- }
- public function testUserExistsSingleBackendNotExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(false);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertFalse($manager->userExists('foo'));
- }
- public function testUserExistsNoBackends() {
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $this->assertFalse($manager->userExists('foo'));
- }
- public function testUserExistsTwoBackendsSecondExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend1
- */
- $backend1 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend1->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(false);
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend2
- */
- $backend2 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend2->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(true);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend1);
- $manager->registerBackend($backend2);
- $this->assertTrue($manager->userExists('foo'));
- }
- public function testUserExistsTwoBackendsFirstExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend1
- */
- $backend1 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend1->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(true);
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend2
- */
- $backend2 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend2->expects($this->never())
- ->method('userExists');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend1);
- $manager->registerBackend($backend2);
- $this->assertTrue($manager->userExists('foo'));
- }
- public function testCheckPassword() {
- /**
- * @var \OC\User\Backend | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('checkPassword')
- ->with($this->equalTo('foo'), $this->equalTo('bar'))
- ->willReturn(true);
- $backend->expects($this->any())
- ->method('implementsActions')
- ->willReturnCallback(function ($actions) {
- if ($actions === \OC\USER\BACKEND::CHECK_PASSWORD) {
- return true;
- } else {
- return false;
- }
- });
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $user = $manager->checkPassword('foo', 'bar');
- $this->assertTrue($user instanceof \OC\User\User);
- }
- public function testCheckPasswordNotSupported() {
- /**
- * @var \OC\User\Backend | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->never())
- ->method('checkPassword');
- $backend->expects($this->any())
- ->method('implementsActions')
- ->willReturn(false);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertFalse($manager->checkPassword('foo', 'bar'));
- }
- public function testGetOneBackendExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(true);
- $backend->expects($this->never())
- ->method('loginName2UserName');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertEquals('foo', $manager->get('foo')->getUID());
- }
- public function testGetOneBackendNotExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(false);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertEquals(null, $manager->get('foo'));
- }
- public function testGetOneBackendDoNotTranslateLoginNames() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('bLeNdEr'))
- ->willReturn(true);
- $backend->expects($this->never())
- ->method('loginName2UserName');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertEquals('bLeNdEr', $manager->get('bLeNdEr')->getUID());
- }
- public function testSearchOneBackend() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('getUsers')
- ->with($this->equalTo('fo'))
- ->willReturn(['foo', 'afoo', 'Afoo1', 'Bfoo']);
- $backend->expects($this->never())
- ->method('loginName2UserName');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $result = $manager->search('fo');
- $this->assertEquals(4, count($result));
- $this->assertEquals('afoo', array_shift($result)->getUID());
- $this->assertEquals('Afoo1', array_shift($result)->getUID());
- $this->assertEquals('Bfoo', array_shift($result)->getUID());
- $this->assertEquals('foo', array_shift($result)->getUID());
- }
- public function testSearchTwoBackendLimitOffset() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend1
- */
- $backend1 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend1->expects($this->once())
- ->method('getUsers')
- ->with($this->equalTo('fo'), $this->equalTo(3), $this->equalTo(1))
- ->willReturn(['foo1', 'foo2']);
- $backend1->expects($this->never())
- ->method('loginName2UserName');
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend2
- */
- $backend2 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend2->expects($this->once())
- ->method('getUsers')
- ->with($this->equalTo('fo'), $this->equalTo(3), $this->equalTo(1))
- ->willReturn(['foo3']);
- $backend2->expects($this->never())
- ->method('loginName2UserName');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend1);
- $manager->registerBackend($backend2);
- $result = $manager->search('fo', 3, 1);
- $this->assertEquals(3, count($result));
- $this->assertEquals('foo1', array_shift($result)->getUID());
- $this->assertEquals('foo2', array_shift($result)->getUID());
- $this->assertEquals('foo3', array_shift($result)->getUID());
- }
- public function dataCreateUserInvalid() {
- return [
- ['te?st', 'foo', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\tst", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\nst", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\rst", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\0st", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\x0Bst", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\xe2st", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\x80st", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ["te\x8bst", '', 'Only the following characters are allowed in a username:'
- . ' "a-z", "A-Z", "0-9", spaces and "_.@-\'"'],
- ['', 'foo', 'A valid username must be provided'],
- [' ', 'foo', 'A valid username must be provided'],
- [' test', 'foo', 'Username contains whitespace at the beginning or at the end'],
- ['test ', 'foo', 'Username contains whitespace at the beginning or at the end'],
- ['.', 'foo', 'Username must not consist of dots only'],
- ['..', 'foo', 'Username must not consist of dots only'],
- ['.test', '', 'A valid password must be provided'],
- ['test', '', 'A valid password must be provided'],
- ];
- }
- /**
- * @dataProvider dataCreateUserInvalid
- */
- public function testCreateUserInvalid($uid, $password, $exception) {
- /** @var \Test\Util\User\Dummy|\PHPUnit\Framework\MockObject\MockObject $backend */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('implementsActions')
- ->with(\OC\User\Backend::CREATE_USER)
- ->willReturn(true);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->expectException(\InvalidArgumentException::class, $exception);
- $manager->createUser($uid, $password);
- }
- public function testCreateUserSingleBackendNotExists() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->any())
- ->method('implementsActions')
- ->willReturn(true);
- $backend->expects($this->once())
- ->method('createUser')
- ->with($this->equalTo('foo'), $this->equalTo('bar'));
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(false);
- $backend->expects($this->never())
- ->method('loginName2UserName');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $user = $manager->createUser('foo', 'bar');
- $this->assertEquals('foo', $user->getUID());
- }
- public function testCreateUserSingleBackendExists() {
- $this->expectException(\Exception::class);
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->any())
- ->method('implementsActions')
- ->willReturn(true);
- $backend->expects($this->never())
- ->method('createUser');
- $backend->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(true);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $manager->createUser('foo', 'bar');
- }
- public function testCreateUserSingleBackendNotSupported() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->any())
- ->method('implementsActions')
- ->willReturn(false);
- $backend->expects($this->never())
- ->method('createUser');
- $backend->expects($this->never())
- ->method('userExists');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $this->assertFalse($manager->createUser('foo', 'bar'));
- }
- public function testCreateUserNoBackends() {
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $this->assertFalse($manager->createUser('foo', 'bar'));
- }
- public function testCreateUserFromBackendWithBackendError() {
- $this->expectException(\InvalidArgumentException::class);
- $this->expectExceptionMessage('Could not create account');
- /** @var IConfig|\PHPUnit\Framework\MockObject\MockObject $config */
- $config = $this->createMock(IConfig::class);
- /** @var \Test\Util\User\Dummy|\PHPUnit\Framework\MockObject\MockObject $backend */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend
- ->expects($this->once())
- ->method('createUser')
- ->with('MyUid', 'MyPassword')
- ->willReturn(false);
- $manager = new Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->createUserFromBackend('MyUid', 'MyPassword', $backend);
- }
- public function testCreateUserTwoBackendExists() {
- $this->expectException(\Exception::class);
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend1
- */
- $backend1 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend1->expects($this->any())
- ->method('implementsActions')
- ->willReturn(true);
- $backend1->expects($this->never())
- ->method('createUser');
- $backend1->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(false);
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend2
- */
- $backend2 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend2->expects($this->any())
- ->method('implementsActions')
- ->willReturn(true);
- $backend2->expects($this->never())
- ->method('createUser');
- $backend2->expects($this->once())
- ->method('userExists')
- ->with($this->equalTo('foo'))
- ->willReturn(true);
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend1);
- $manager->registerBackend($backend2);
- $manager->createUser('foo', 'bar');
- }
- public function testCountUsersNoBackend() {
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $result = $manager->countUsers();
- $this->assertTrue(is_array($result));
- $this->assertTrue(empty($result));
- }
- public function testCountUsersOneBackend() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->once())
- ->method('countUsers')
- ->willReturn(7);
- $backend->expects($this->once())
- ->method('implementsActions')
- ->with(\OC\USER\BACKEND::COUNT_USERS)
- ->willReturn(true);
- $backend->expects($this->once())
- ->method('getBackendName')
- ->willReturn('Mock_Test_Util_User_Dummy');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $result = $manager->countUsers();
- $keys = array_keys($result);
- $this->assertTrue(strpos($keys[0], 'Mock_Test_Util_User_Dummy') !== false);
- $users = array_shift($result);
- $this->assertEquals(7, $users);
- }
- public function testCountUsersTwoBackends() {
- /**
- * @var \Test\Util\User\Dummy | \PHPUnit\Framework\MockObject\MockObject $backend
- */
- $backend1 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend1->expects($this->once())
- ->method('countUsers')
- ->willReturn(7);
- $backend1->expects($this->once())
- ->method('implementsActions')
- ->with(\OC\USER\BACKEND::COUNT_USERS)
- ->willReturn(true);
- $backend1->expects($this->once())
- ->method('getBackendName')
- ->willReturn('Mock_Test_Util_User_Dummy');
- $backend2 = $this->createMock(\Test\Util\User\Dummy::class);
- $backend2->expects($this->once())
- ->method('countUsers')
- ->willReturn(16);
- $backend2->expects($this->once())
- ->method('implementsActions')
- ->with(\OC\USER\BACKEND::COUNT_USERS)
- ->willReturn(true);
- $backend2->expects($this->once())
- ->method('getBackendName')
- ->willReturn('Mock_Test_Util_User_Dummy');
- $manager = new \OC\User\Manager($this->config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend1);
- $manager->registerBackend($backend2);
- $result = $manager->countUsers();
- //because the backends have the same class name, only one value expected
- $this->assertEquals(1, count($result));
- $keys = array_keys($result);
- $this->assertTrue(strpos($keys[0], 'Mock_Test_Util_User_Dummy') !== false);
- $users = array_shift($result);
- //users from backends shall be summed up
- $this->assertEquals(7 + 16, $users);
- }
- public function testCountUsersOnlyDisabled() {
- $manager = \OCP\Server::get(IUserManager::class);
- // count other users in the db before adding our own
- $countBefore = $manager->countDisabledUsers();
- //Add test users
- $user1 = $manager->createUser('testdisabledcount1', 'testdisabledcount1');
- $user2 = $manager->createUser('testdisabledcount2', 'testdisabledcount2');
- $user2->setEnabled(false);
- $user3 = $manager->createUser('testdisabledcount3', 'testdisabledcount3');
- $user4 = $manager->createUser('testdisabledcount4', 'testdisabledcount4');
- $user4->setEnabled(false);
- $this->assertEquals($countBefore + 2, $manager->countDisabledUsers());
- //cleanup
- $user1->delete();
- $user2->delete();
- $user3->delete();
- $user4->delete();
- }
- public function testCountUsersOnlySeen() {
- $manager = \OCP\Server::get(IUserManager::class);
- // count other users in the db before adding our own
- $countBefore = $manager->countSeenUsers();
- //Add test users
- $user1 = $manager->createUser('testseencount1', 'testseencount1');
- $user1->updateLastLoginTimestamp();
- $user2 = $manager->createUser('testseencount2', 'testseencount2');
- $user2->updateLastLoginTimestamp();
- $user3 = $manager->createUser('testseencount3', 'testseencount3');
- $user4 = $manager->createUser('testseencount4', 'testseencount4');
- $user4->updateLastLoginTimestamp();
- $this->assertEquals($countBefore + 3, $manager->countSeenUsers());
- //cleanup
- $user1->delete();
- $user2->delete();
- $user3->delete();
- $user4->delete();
- }
- public function testCallForSeenUsers() {
- $manager = \OCP\Server::get(IUserManager::class);
- // count other users in the db before adding our own
- $count = 0;
- $function = function (IUser $user) use (&$count) {
- $count++;
- };
- $manager->callForAllUsers($function, '', true);
- $countBefore = $count;
- //Add test users
- $user1 = $manager->createUser('testseen1', 'testseen10');
- $user1->updateLastLoginTimestamp();
- $user2 = $manager->createUser('testseen2', 'testseen20');
- $user2->updateLastLoginTimestamp();
- $user3 = $manager->createUser('testseen3', 'testseen30');
- $user4 = $manager->createUser('testseen4', 'testseen40');
- $user4->updateLastLoginTimestamp();
- $count = 0;
- $manager->callForAllUsers($function, '', true);
- $this->assertEquals($countBefore + 3, $count);
- //cleanup
- $user1->delete();
- $user2->delete();
- $user3->delete();
- $user4->delete();
- }
- /**
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testRecentlyActive(): void {
- $config = \OCP\Server::get(IConfig::class);
- $manager = \OCP\Server::get(IUserManager::class);
- // Create some users
- $now = (string)time();
- $user1 = $manager->createUser('test_active_1', 'test_active_1');
- $config->setUserValue('test_active_1', 'login', 'lastLogin', $now);
- $user1->setDisplayName('test active 1');
- $user1->setSystemEMailAddress('roger@active.com');
- $user2 = $manager->createUser('TEST_ACTIVE_2_FRED', 'TEST_ACTIVE_2');
- $config->setUserValue('TEST_ACTIVE_2_FRED', 'login', 'lastLogin', $now);
- $user2->setDisplayName('TEST ACTIVE 2 UPPER');
- $user2->setSystemEMailAddress('Fred@Active.Com');
- $user3 = $manager->createUser('test_active_3', 'test_active_3');
- $config->setUserValue('test_active_3', 'login', 'lastLogin', $now + 1);
- $user3->setDisplayName('test active 3');
- $user4 = $manager->createUser('test_active_4', 'test_active_4');
- $config->setUserValue('test_active_4', 'login', 'lastLogin', $now);
- $user4->setDisplayName('Test Active 4');
- $user5 = $manager->createUser('test_inactive_1', 'test_inactive_1');
- $user5->setDisplayName('Test Inactive 1');
- $user2->setSystemEMailAddress('jeanne@Active.Com');
- // Search recently active
- // - No search, case-insensitive order
- $users = $manager->getLastLoggedInUsers(4);
- $this->assertEquals(['test_active_3', 'test_active_1', 'TEST_ACTIVE_2_FRED', 'test_active_4'], $users);
- // - Search, case-insensitive order
- $users = $manager->getLastLoggedInUsers(search: 'act');
- $this->assertEquals(['test_active_3', 'test_active_1', 'TEST_ACTIVE_2_FRED', 'test_active_4'], $users);
- // - No search with offset
- $users = $manager->getLastLoggedInUsers(2, 2);
- $this->assertEquals(['TEST_ACTIVE_2_FRED', 'test_active_4'], $users);
- // - Case insensitive search (email)
- $users = $manager->getLastLoggedInUsers(search: 'active.com');
- $this->assertEquals(['test_active_1', 'TEST_ACTIVE_2_FRED'], $users);
- // - Case insensitive search (display name)
- $users = $manager->getLastLoggedInUsers(search: 'upper');
- $this->assertEquals(['TEST_ACTIVE_2_FRED'], $users);
- // - Case insensitive search (uid)
- $users = $manager->getLastLoggedInUsers(search: 'fred');
- $this->assertEquals(['TEST_ACTIVE_2_FRED'], $users);
- // Delete users and config keys
- $user1->delete();
- $user2->delete();
- $user3->delete();
- $user4->delete();
- $user5->delete();
- }
- public function testDeleteUser() {
- $config = $this->getMockBuilder(AllConfig::class)
- ->disableOriginalConstructor()
- ->getMock();
- $config
- ->expects($this->any())
- ->method('getUserValue')
- ->willReturnArgument(3);
- $config
- ->expects($this->any())
- ->method('getAppValue')
- ->willReturnArgument(2);
- $manager = new \OC\User\Manager($config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $backend = new \Test\Util\User\Dummy();
- $manager->registerBackend($backend);
- $backend->createUser('foo', 'bar');
- $this->assertTrue($manager->userExists('foo'));
- $manager->get('foo')->delete();
- $this->assertFalse($manager->userExists('foo'));
- }
- public function testGetByEmail() {
- $config = $this->getMockBuilder(AllConfig::class)
- ->disableOriginalConstructor()
- ->getMock();
- $config
- ->expects($this->once())
- ->method('getUsersForUserValueCaseInsensitive')
- ->with('settings', 'email', 'test@example.com')
- ->willReturn(['uid1', 'uid99', 'uid2']);
- $backend = $this->createMock(\Test\Util\User\Dummy::class);
- $backend->expects($this->exactly(3))
- ->method('userExists')
- ->withConsecutive(
- [$this->equalTo('uid1')],
- [$this->equalTo('uid99')],
- [$this->equalTo('uid2')]
- )
- ->willReturnOnConsecutiveCalls(
- true,
- false,
- true
- );
- $manager = new \OC\User\Manager($config, $this->cacheFactory, $this->eventDispatcher, $this->logger);
- $manager->registerBackend($backend);
- $users = $manager->getByEmail('test@example.com');
- $this->assertCount(2, $users);
- $this->assertEquals('uid1', $users[0]->getUID());
- $this->assertEquals('uid2', $users[1]->getUID());
- }
- }
|