Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@arthur-schiwon.de>2018-12-17 16:55:00 +0300
committerArthur Schiwon <blizzz@arthur-schiwon.de>2018-12-21 19:24:23 +0300
commitfbd4e9e6513426b0809fcc6fc1faec72e6b52d2d (patch)
tree8467489a0f67a0b95da30322079d8966a071f48f /apps/user_ldap/tests
parent58d4b8ee859afa62248bdef5024afd1eb98f68dc (diff)
add tests for the DUI
as they are interact with the DB they are more integraiton than unit tests Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
Diffstat (limited to 'apps/user_ldap/tests')
-rw-r--r--apps/user_ldap/tests/User/DeletedUsersIndexTest.php118
1 files changed, 118 insertions, 0 deletions
diff --git a/apps/user_ldap/tests/User/DeletedUsersIndexTest.php b/apps/user_ldap/tests/User/DeletedUsersIndexTest.php
new file mode 100644
index 00000000000..b3cf076e973
--- /dev/null
+++ b/apps/user_ldap/tests/User/DeletedUsersIndexTest.php
@@ -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());
+ }
+ }
+
+
+}