as they are interact with the DB they are more integraiton than unit tests Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>pull/13138/head
parent
58d4b8ee85
commit
fbd4e9e651
@ -0,0 +1,118 @@ |
||||
<?php |
||||
/** |
||||
* @copyright Copyright (c) 2018 Arthur Schiwon <blizzz@arthur-schiwon.de> |
||||
* |
||||
* @author Arthur Schiwon <blizzz@arthur-schiwon.de> |
||||
* |
||||
* @license GNU AGPL version 3 or any later version |
||||
* |
||||
* This program is free software: you can redistribute it and/or modify |
||||
* it under the terms of the GNU Affero General Public License as |
||||
* published by the Free Software Foundation, either version 3 of the |
||||
* License, or (at your option) any later version. |
||||
* |
||||
* This program is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
* GNU Affero General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Affero General Public License |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
* |
||||
*/ |
||||
|
||||
namespace OCA\User_LDAP\Tests\User; |
||||
|
||||
use OCA\User_LDAP\Mapping\UserMapping; |
||||
use OCA\User_LDAP\User\DeletedUsersIndex; |
||||
use OCP\IConfig; |
||||
use OCP\IDBConnection; |
||||
|
||||
/** |
||||
* Class DeletedUsersIndexTest |
||||
* |
||||
* @group DB |
||||
* |
||||
* @package OCA\User_LDAP\Tests\User |
||||
*/ |
||||
class DeletedUsersIndexTest extends \Test\TestCase { |
||||
/** @var DeletedUsersIndex */ |
||||
protected $dui; |
||||
|
||||
/** @var IConfig */ |
||||
protected $config; |
||||
|
||||
/** @var IDBConnection */ |
||||
protected $db; |
||||
|
||||
/** @var UserMapping|\PHPUnit_Framework_MockObject_MockObject */ |
||||
protected $mapping; |
||||
|
||||
public function setUp() { |
||||
parent::setUp(); |
||||
|
||||
// no mocks for those as tests go against DB |
||||
$this->config = \OC::$server->getConfig(); |
||||
$this->db = \OC::$server->getDatabaseConnection(); |
||||
|
||||
$this->mapping = $this->createMock(UserMapping::class); |
||||
|
||||
$this->dui = new DeletedUsersIndex($this->config, $this->db, $this->mapping); |
||||
} |
||||
|
||||
public function tearDown() { |
||||
$this->config->deleteAppFromAllUsers('user_ldap'); |
||||
return parent::tearDown(); |
||||
} |
||||
|
||||
public function testMarkAndFetchUser() { |
||||
$uids = [ |
||||
'cef3775c-71d2-48eb-8984-39a4051b0b95', |
||||
'8c4bbb40-33ed-42d0-9b14-85b0ab76c1cc', |
||||
]; |
||||
|
||||
// ensure test works on a pristine state |
||||
$this->assertFalse($this->dui->hasUsers()); |
||||
|
||||
$this->dui->markUser($uids[0]); |
||||
|
||||
$this->assertTrue($this->dui->hasUsers()); |
||||
|
||||
$this->dui->markUser($uids[1]); |
||||
|
||||
$deletedUsers = $this->dui->getUsers(); |
||||
$this->assertSame(2, count($deletedUsers)); |
||||
|
||||
// ensure the different uids were used |
||||
foreach($deletedUsers as $deletedUser) { |
||||
$this->assertTrue(in_array($deletedUser->getOCName(), $uids)); |
||||
$i = array_search($deletedUser->getOCName(), $uids); |
||||
$this->assertNotFalse($i); |
||||
unset($uids[$i]); |
||||
} |
||||
$this->assertEmpty($uids); |
||||
} |
||||
|
||||
public function testUnmarkUser() { |
||||
$uids = [ |
||||
'22a162c7-a9ee-487c-9f33-0563795583fb', |
||||
'1fb4e0da-4a75-47f3-8fa7-becc7e35c9c5', |
||||
]; |
||||
|
||||
// we know this works, because of "testMarkAndFetchUser" |
||||
$this->dui->markUser($uids[0]); |
||||
// this returns a working instance of OfflineUser |
||||
$testUser = $this->dui->getUsers()[0]; |
||||
$testUser->unmark(); |
||||
|
||||
// the DUI caches the users, to clear mark someone else |
||||
$this->dui->markUser($uids[1]); |
||||
|
||||
$deletedUsers = $this->dui->getUsers(); |
||||
foreach ($deletedUsers as $deletedUser) { |
||||
$this->assertNotSame($testUser->getOCName(), $deletedUser->getOCName()); |
||||
} |
||||
} |
||||
|
||||
|
||||
} |
||||
Loading…
Reference in new issue