diff options
author | Robin Appelman <icewind@owncloud.com> | 2015-08-10 14:39:34 +0200 |
---|---|---|
committer | Robin Appelman <icewind@owncloud.com> | 2015-08-10 14:39:34 +0200 |
commit | d979e54030b0069572affe173c06680597cc831d (patch) | |
tree | 63d72d28ae9aaaffe841aaa0274cd47263a67232 | |
parent | 58e96e53b039365751eb8c4a2d511fcfcf507891 (diff) | |
download | nextcloud-server-d979e54030b0069572affe173c06680597cc831d.tar.gz nextcloud-server-d979e54030b0069572affe173c06680597cc831d.zip |
log a warning while trying to acquire a db lock from within a transaction
-rw-r--r-- | lib/private/lock/dblockingprovider.php | 14 | ||||
-rw-r--r-- | lib/private/server.php | 8 | ||||
-rw-r--r-- | tests/lib/lock/dblockingprovider.php | 2 |
3 files changed, 18 insertions, 6 deletions
diff --git a/lib/private/lock/dblockingprovider.php b/lib/private/lock/dblockingprovider.php index 5480a6e53af..5241a0440b3 100644 --- a/lib/private/lock/dblockingprovider.php +++ b/lib/private/lock/dblockingprovider.php @@ -22,6 +22,7 @@ namespace OC\Lock; use OCP\IDBConnection; +use OCP\ILogger; use OCP\Lock\LockedException; /** @@ -34,10 +35,17 @@ class DBLockingProvider extends AbstractLockingProvider { private $connection; /** + * @var \OCP\ILogger + */ + private $logger; + + /** * @param \OCP\IDBConnection $connection + * @param \OCP\ILogger $logger */ - public function __construct(IDBConnection $connection) { + public function __construct(IDBConnection $connection, ILogger $logger) { $this->connection = $connection; + $this->logger = $logger; } protected function initLockField($path) { @@ -68,6 +76,10 @@ class DBLockingProvider extends AbstractLockingProvider { * @throws \OCP\Lock\LockedException */ public function acquireLock($path, $type) { + if ($this->connection->inTransaction()){ + $this->logger->warning('Trying to acquire a lock while inside a transition'); + } + $this->connection->beginTransaction(); $this->initLockField($path); if ($type === self::LOCK_SHARED) { diff --git a/lib/private/server.php b/lib/private/server.php index 51e70405432..be2cfc2cf88 100644 --- a/lib/private/server.php +++ b/lib/private/server.php @@ -432,10 +432,10 @@ class Server extends SimpleContainer implements IServerContainer { /** @var \OC\Memcache\Factory $memcacheFactory */ $memcacheFactory = $c->getMemCacheFactory(); $memcache = $memcacheFactory->createLocking('lock'); - if (!($memcache instanceof \OC\Memcache\NullCache)) { - return new MemcacheLockingProvider($memcache); - } - return new DBLockingProvider($c->getDatabaseConnection()); +// if (!($memcache instanceof \OC\Memcache\NullCache)) { +// return new MemcacheLockingProvider($memcache); +// } + return new DBLockingProvider($c->getDatabaseConnection(), $c->getLogger()); } return new NoopLockingProvider(); }); diff --git a/tests/lib/lock/dblockingprovider.php b/tests/lib/lock/dblockingprovider.php index 4818ef1ceca..fd6550d9c47 100644 --- a/tests/lib/lock/dblockingprovider.php +++ b/tests/lib/lock/dblockingprovider.php @@ -33,7 +33,7 @@ class DBLockingProvider extends LockingProvider { */ protected function getInstance() { $this->connection = \OC::$server->getDatabaseConnection(); - return new \OC\Lock\DBLockingProvider($this->connection); + return new \OC\Lock\DBLockingProvider($this->connection, \OC::$server->getLogger()); } public function tearDown() { |