summaryrefslogtreecommitdiffstats
path: root/tests/lib/Lock
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2018-04-10 18:30:43 +0200
committerRobin Appelman <robin@icewind.nl>2018-04-11 19:21:45 +0200
commit89a9d35d90b7264d66411dfefec0aa84491d5cf9 (patch)
tree8e433546babedc20917bb0b81fa59f7438a4dfc5 /tests/lib/Lock
parent9260474ab69e85c292ac1b845a52e4ddf838d4ae (diff)
downloadnextcloud-server-89a9d35d90b7264d66411dfefec0aa84491d5cf9.tar.gz
nextcloud-server-89a9d35d90b7264d66411dfefec0aa84491d5cf9.zip
dont keep shared database locks when running cli scripts
For cli scripts we don't have the assumption that the universe will be cleaned up soon Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'tests/lib/Lock')
-rw-r--r--tests/lib/Lock/DBLockingProviderTest.php33
-rw-r--r--tests/lib/Lock/NonCachingDBLockingProviderTest.php54
2 files changed, 84 insertions, 3 deletions
diff --git a/tests/lib/Lock/DBLockingProviderTest.php b/tests/lib/Lock/DBLockingProviderTest.php
index fb27f9957af..e8419815e31 100644
--- a/tests/lib/Lock/DBLockingProviderTest.php
+++ b/tests/lib/Lock/DBLockingProviderTest.php
@@ -40,14 +40,14 @@ class DBLockingProviderTest extends LockingProvider {
/**
* @var \OCP\IDBConnection
*/
- private $connection;
+ protected $connection;
/**
* @var \OCP\AppFramework\Utility\ITimeFactory
*/
- private $timeFactory;
+ protected $timeFactory;
- private $currentTime;
+ protected $currentTime;
public function setUp() {
$this->currentTime = time();
@@ -96,4 +96,31 @@ class DBLockingProviderTest extends LockingProvider {
$query->execute();
return $query->fetchColumn();
}
+
+ protected function getLockValue($key) {
+ $query = $this->connection->getQueryBuilder();
+ $query->select('lock')
+ ->from('file_locks')
+ ->where($query->expr()->eq('key', $query->createNamedParameter($key)));
+ return $query->execute()->fetchColumn();
+ }
+
+ public function testDoubleShared() {
+ $this->instance->acquireLock('foo', ILockingProvider::LOCK_SHARED);
+ $this->instance->acquireLock('foo', ILockingProvider::LOCK_SHARED);
+
+ $this->assertEquals(1, $this->getLockValue('foo'));
+
+ $this->instance->releaseLock('foo', ILockingProvider::LOCK_SHARED);
+
+ $this->assertEquals(1, $this->getLockValue('foo'));
+
+ $this->instance->releaseLock('foo', ILockingProvider::LOCK_SHARED);
+
+ $this->assertEquals(1, $this->getLockValue('foo'));
+
+ $this->instance->releaseAll();
+
+ $this->assertEquals(0, $this->getLockValue('foo'));
+ }
}
diff --git a/tests/lib/Lock/NonCachingDBLockingProviderTest.php b/tests/lib/Lock/NonCachingDBLockingProviderTest.php
new file mode 100644
index 00000000000..be5cd1600c8
--- /dev/null
+++ b/tests/lib/Lock/NonCachingDBLockingProviderTest.php
@@ -0,0 +1,54 @@
+<?php
+/**
+ * @copyright Copyright (c) 2018 Robin Appelman <robin@icewind.nl>
+ *
+ * @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 Test\Lock;
+
+use OCP\Lock\ILockingProvider;
+
+/**
+ * @group DB
+ *
+ * @package Test\Lock
+ */
+class NonCachingDBLockingProviderTest extends DBLockingProviderTest {
+ /**
+ * @return \OCP\Lock\ILockingProvider
+ */
+ protected function getInstance() {
+ $this->connection = \OC::$server->getDatabaseConnection();
+ return new \OC\Lock\DBLockingProvider($this->connection, \OC::$server->getLogger(), $this->timeFactory, 3600, false);
+ }
+
+ public function testDoubleShared() {
+ $this->instance->acquireLock('foo', ILockingProvider::LOCK_SHARED);
+ $this->instance->acquireLock('foo', ILockingProvider::LOCK_SHARED);
+
+ $this->assertEquals(2, $this->getLockValue('foo'));
+
+ $this->instance->releaseLock('foo', ILockingProvider::LOCK_SHARED);
+
+ $this->assertEquals(1, $this->getLockValue('foo'));
+
+ $this->instance->releaseLock('foo', ILockingProvider::LOCK_SHARED);
+
+ $this->assertEquals(0, $this->getLockValue('foo'));
+ }
+} \ No newline at end of file