[Pkg-owncloud-commits] [owncloud] 44/103: Add unit tests for external share mananger

David Prévot taffit at moszumanska.debian.org
Sun May 31 12:32:36 UTC 2015


This is an automated email from the git hooks/post-receive script.

taffit pushed a commit to annotated tag v8.0.4RC1
in repository owncloud.

commit 1aeb4c0e8c046ed386d2e52957bf61cba58eefa3
Author: Robin Appelman <icewind at owncloud.com>
Date:   Fri Feb 27 13:34:17 2015 +0100

    Add unit tests for external share mananger
---
 apps/files_sharing/lib/external/manager.php   |   4 +-
 apps/files_sharing/tests/external/manager.php | 142 ++++++++++++++++++++++++++
 2 files changed, 144 insertions(+), 2 deletions(-)

diff --git a/apps/files_sharing/lib/external/manager.php b/apps/files_sharing/lib/external/manager.php
index 8985aeb..cdd8fac 100644
--- a/apps/files_sharing/lib/external/manager.php
+++ b/apps/files_sharing/lib/external/manager.php
@@ -94,7 +94,7 @@ class Manager {
 		}
 	}
 
-	private function setupMounts() {
+	public function setupMounts() {
 		// don't setup server-to-server shares if the admin disabled it
 		if (\OCA\Files_Sharing\Helper::isIncomingServer2serverShareEnabled() === false) {
 			return false;
@@ -321,4 +321,4 @@ class Manager {
 		return $result ? $openShares->fetchAll() : array();
 
 	}
-}
\ No newline at end of file
+}
diff --git a/apps/files_sharing/tests/external/manager.php b/apps/files_sharing/tests/external/manager.php
new file mode 100644
index 0000000..fa98e8a
--- /dev/null
+++ b/apps/files_sharing/tests/external/manager.php
@@ -0,0 +1,142 @@
+<?php
+/**
+ * @author Robin Appelman <icewind at owncloud.com>
+ *
+ * @copyright Copyright (c) 2015, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * 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, version 3,
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+namespace OCA\Files_sharing\Tests\External;
+
+use OC\Files\Storage\StorageFactory;
+use Test\TestCase;
+
+class Manager extends TestCase {
+	private $uid;
+
+	/**
+	 * @var \OC\Files\Mount\Manager
+	 */
+	private $mountManager;
+
+	/**
+	 * @var \OCA\Files_Sharing\External\Manager
+	 */
+	private $instance;
+
+	public function setUp() {
+		$this->uid = uniqid();
+		$this->mountManager = new \OC\Files\Mount\Manager();
+		$this->instance = new \OCA\Files_Sharing\External\Manager(\OC::$server->getDatabaseConnection(),
+			$this->mountManager, new StorageFactory(), \OC::$server->getHTTPHelper(), $this->uid);
+	}
+
+	public function tearDown() {
+		$this->instance->removeUserShares($this->uid);
+	}
+
+	private function getFullPath($path) {
+		return '/' . $this->uid . '/files' . $path;
+	}
+
+	private function assertMount($mountPoint) {
+		$mountPoint = rtrim($mountPoint, '/');
+		$mount = $this->mountManager->find($this->getFullPath($mountPoint));
+		$this->assertInstanceOf('\OCP\Files\Mount\IMountPoint', $mount);
+		$this->assertEquals($this->getFullPath($mountPoint), rtrim($mount->getMountPoint(), '/'));
+		$storage = $mount->getStorage();
+		$this->assertInstanceOf('\OCA\Files_Sharing\External\Storage', $storage);
+	}
+
+	private function assertNotMount($mountPoint) {
+		$mountPoint = rtrim($mountPoint, '/');
+		$mount = $this->mountManager->find($this->getFullPath($mountPoint));
+		if ($mount) {
+			$this->assertInstanceOf('\OCP\Files\Mount\IMountPoint', $mount);
+			$this->assertNotEquals($this->getFullPath($mountPoint), rtrim($mount->getMountPoint(), '/'));
+		} else {
+			$this->assertNull($mount);
+		}
+	}
+
+	public function testAddBasic() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', true);
+		$this->instance->setupMounts();
+		$this->assertMount('/example');
+	}
+
+	public function testAddBasicEmptyPassword() {
+		$this->instance->addShare('http://example.com', 'foo', '', 'example', 'me', true);
+		$this->instance->setupMounts();
+		$this->assertMount('/example');
+	}
+
+	public function testAddNotAcceptedShare() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', false);
+		$this->instance->setupMounts();
+		$this->assertNotMount('/example');
+	}
+
+	public function testAcceptMount() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', false);
+		$open = $this->instance->getOpenShares();
+		$this->assertCount(1, $open);
+		$this->instance->acceptShare($open[0]['id']);
+		$this->assertEquals([], $this->instance->getOpenShares());
+		$this->instance->setupMounts();
+		$this->assertMount('/example');
+	}
+
+	public function testDeclineMount() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', false);
+		$open = $this->instance->getOpenShares();
+		$this->assertCount(1, $open);
+		$this->instance->declineShare($open[0]['id']);
+		$this->assertEquals([], $this->instance->getOpenShares());
+		$this->instance->setupMounts();
+		$this->assertNotMount('/example');
+	}
+
+	public function testSetMountPoint() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', true);
+		$this->instance->setupMounts();
+		$this->assertMount('/example');
+		$this->instance->setMountPoint($this->getFullPath('/example'), $this->getFullPath('/renamed'));
+		$this->mountManager->clear();
+		$this->instance->setupMounts();
+		$this->assertMount('/renamed');
+		$this->assertNotMount('/example');
+	}
+
+	public function testRemoveShare() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', true);
+		$this->instance->setupMounts();
+		$this->assertMount('/example');
+		$this->instance->removeShare($this->getFullPath('/example'));
+		$this->mountManager->clear();
+		$this->instance->setupMounts();
+		$this->assertNotMount('/example');
+	}
+
+	public function testRemoveShareForUser() {
+		$this->instance->addShare('http://example.com', 'foo', 'bar', 'example', 'me', true);
+		$this->instance->setupMounts();
+		$this->assertMount('/example');
+		$this->instance->removeUserShares($this->uid);
+		$this->mountManager->clear();
+		$this->instance->setupMounts();
+		$this->assertNotMount('/example');
+	}
+}

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-owncloud/owncloud.git



More information about the Pkg-owncloud-commits mailing list