2013-11-05 22:30:52 +04:00
|
|
|
<?php
|
|
|
|
/**
|
2015-03-26 13:44:34 +03:00
|
|
|
* @author Björn Schießle <schiessle@owncloud.com>
|
|
|
|
* @author Joas Schilling <nickvergessen@owncloud.com>
|
|
|
|
* @author Jörn Friedrich Dreyer <jfd@butonic.de>
|
|
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
2015-06-25 12:43:55 +03:00
|
|
|
* @author Robin Appelman <icewind@owncloud.com>
|
2015-03-26 13:44:34 +03:00
|
|
|
* @author Thomas Müller <thomas.mueller@tmit.eu>
|
|
|
|
* @author Vincent Petry <pvince81@owncloud.com>
|
2013-11-05 22:30:52 +04:00
|
|
|
*
|
2015-03-26 13:44:34 +03:00
|
|
|
* @copyright Copyright (c) 2015, ownCloud, Inc.
|
|
|
|
* @license AGPL-3.0
|
2013-11-05 22:30:52 +04:00
|
|
|
*
|
2015-03-26 13:44:34 +03:00
|
|
|
* 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.
|
2013-11-05 22:30:52 +04:00
|
|
|
*
|
2015-03-26 13:44:34 +03:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
2013-11-05 22:30:52 +04:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2015-03-26 13:44:34 +03:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
2013-11-05 22:30:52 +04:00
|
|
|
*
|
2015-03-26 13:44:34 +03:00
|
|
|
* 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/>
|
2013-11-05 22:30:52 +04:00
|
|
|
*
|
|
|
|
*/
|
2015-02-26 13:37:37 +03:00
|
|
|
|
2015-11-03 03:52:41 +03:00
|
|
|
/**
|
|
|
|
* Class Test_Files_Sharing_Watcher
|
|
|
|
*
|
|
|
|
* @group DB
|
|
|
|
*/
|
2014-10-30 19:20:40 +03:00
|
|
|
class Test_Files_Sharing_Watcher extends OCA\Files_sharing\Tests\TestCase {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Storage\Storage
|
|
|
|
*/
|
|
|
|
private $ownerStorage;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Cache\Cache
|
|
|
|
*/
|
|
|
|
private $ownerCache;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Storage\Storage
|
|
|
|
*/
|
|
|
|
private $sharedStorage;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Cache\Cache
|
|
|
|
*/
|
|
|
|
private $sharedCache;
|
2013-11-05 22:30:52 +04:00
|
|
|
|
2014-11-11 00:28:12 +03:00
|
|
|
protected function setUp() {
|
2013-11-05 22:30:52 +04:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
self::loginHelper(self::TEST_FILES_SHARING_API_USER1);
|
|
|
|
|
|
|
|
// prepare user1's dir structure
|
|
|
|
$textData = "dummy file data\n";
|
|
|
|
$this->view->mkdir('container');
|
|
|
|
$this->view->mkdir('container/shareddir');
|
|
|
|
$this->view->mkdir('container/shareddir/subdir');
|
|
|
|
|
|
|
|
list($this->ownerStorage, $internalPath) = $this->view->resolvePath('');
|
|
|
|
$this->ownerCache = $this->ownerStorage->getCache();
|
|
|
|
$this->ownerStorage->getScanner()->scan('');
|
|
|
|
|
|
|
|
// share "shareddir" with user2
|
|
|
|
$fileinfo = $this->view->getFileInfo('container/shareddir');
|
|
|
|
\OCP\Share::shareItem('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_USER,
|
|
|
|
self::TEST_FILES_SHARING_API_USER2, 31);
|
|
|
|
|
|
|
|
// login as user2
|
|
|
|
self::loginHelper(self::TEST_FILES_SHARING_API_USER2);
|
|
|
|
|
|
|
|
// retrieve the shared storage
|
|
|
|
$secondView = new \OC\Files\View('/' . self::TEST_FILES_SHARING_API_USER2);
|
2014-04-08 21:57:07 +04:00
|
|
|
list($this->sharedStorage, $internalPath) = $secondView->resolvePath('files/shareddir');
|
2013-11-05 22:30:52 +04:00
|
|
|
$this->sharedCache = $this->sharedStorage->getCache();
|
|
|
|
}
|
|
|
|
|
2014-11-11 00:28:12 +03:00
|
|
|
protected function tearDown() {
|
2015-04-24 19:10:32 +03:00
|
|
|
if ($this->sharedCache) {
|
|
|
|
$this->sharedCache->clear();
|
|
|
|
}
|
2013-11-05 22:30:52 +04:00
|
|
|
|
2013-11-06 12:39:52 +04:00
|
|
|
self::loginHelper(self::TEST_FILES_SHARING_API_USER1);
|
|
|
|
|
2013-11-05 22:30:52 +04:00
|
|
|
$fileinfo = $this->view->getFileInfo('container/shareddir');
|
|
|
|
\OCP\Share::unshare('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_USER,
|
|
|
|
self::TEST_FILES_SHARING_API_USER2);
|
|
|
|
|
|
|
|
$this->view->deleteAll('container');
|
|
|
|
|
|
|
|
$this->ownerCache->clear();
|
|
|
|
|
|
|
|
parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests that writing a file using the shared storage will propagate the file
|
|
|
|
* size to the owner's parent folders.
|
|
|
|
*/
|
|
|
|
function testFolderSizePropagationToOwnerStorage() {
|
|
|
|
$initialSizes = self::getOwnerDirSizes('files/container/shareddir');
|
|
|
|
|
|
|
|
$textData = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
|
|
|
$dataLen = strlen($textData);
|
2014-04-08 21:57:07 +04:00
|
|
|
$this->sharedCache->put('bar.txt', array('mtime' => 10, 'storage_mtime' => 10, 'size' => $dataLen, 'mimetype' => 'text/plain'));
|
|
|
|
$this->sharedStorage->file_put_contents('bar.txt', $textData);
|
|
|
|
$this->sharedCache->put('', array('mtime' => 10, 'storage_mtime' => 10, 'size' => '-1', 'mimetype' => 'httpd/unix-directory'));
|
2013-11-05 22:30:52 +04:00
|
|
|
|
|
|
|
// run the propagation code
|
2015-10-12 18:43:44 +03:00
|
|
|
$this->sharedStorage->getWatcher()->checkUpdate('');
|
|
|
|
$this->sharedStorage->getCache()->correctFolderSize('');
|
2013-11-05 22:30:52 +04:00
|
|
|
|
|
|
|
// the owner's parent dirs must have increase size
|
|
|
|
$newSizes = self::getOwnerDirSizes('files/container/shareddir');
|
|
|
|
$this->assertEquals($initialSizes[''] + $dataLen, $newSizes['']);
|
|
|
|
$this->assertEquals($initialSizes['files'] + $dataLen, $newSizes['files']);
|
|
|
|
$this->assertEquals($initialSizes['files/container'] + $dataLen, $newSizes['files/container']);
|
|
|
|
$this->assertEquals($initialSizes['files/container/shareddir'] + $dataLen, $newSizes['files/container/shareddir']);
|
|
|
|
|
|
|
|
// no more updates
|
2014-04-08 21:57:07 +04:00
|
|
|
$result = $this->sharedStorage->getWatcher()->checkUpdate('');
|
2013-11-05 22:30:52 +04:00
|
|
|
|
|
|
|
$this->assertFalse($result);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests that writing a file using the shared storage will propagate the file
|
|
|
|
* size to the owner's parent folders.
|
|
|
|
*/
|
|
|
|
function testSubFolderSizePropagationToOwnerStorage() {
|
|
|
|
$initialSizes = self::getOwnerDirSizes('files/container/shareddir/subdir');
|
|
|
|
|
|
|
|
$textData = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
|
|
|
$dataLen = strlen($textData);
|
2014-04-08 21:57:07 +04:00
|
|
|
$this->sharedCache->put('subdir/bar.txt', array('mtime' => 10, 'storage_mtime' => 10, 'size' => $dataLen, 'mimetype' => 'text/plain'));
|
|
|
|
$this->sharedStorage->file_put_contents('subdir/bar.txt', $textData);
|
|
|
|
$this->sharedCache->put('subdir', array('mtime' => 10, 'storage_mtime' => 10, 'size' => $dataLen, 'mimetype' => 'text/plain'));
|
2013-11-05 22:30:52 +04:00
|
|
|
|
|
|
|
// run the propagation code
|
2015-10-12 18:43:44 +03:00
|
|
|
$this->sharedStorage->getWatcher()->checkUpdate('subdir');
|
|
|
|
$this->sharedStorage->getCache()->correctFolderSize('subdir');
|
2013-11-05 22:30:52 +04:00
|
|
|
|
|
|
|
// the owner's parent dirs must have increase size
|
|
|
|
$newSizes = self::getOwnerDirSizes('files/container/shareddir/subdir');
|
|
|
|
$this->assertEquals($initialSizes[''] + $dataLen, $newSizes['']);
|
|
|
|
$this->assertEquals($initialSizes['files'] + $dataLen, $newSizes['files']);
|
|
|
|
$this->assertEquals($initialSizes['files/container'] + $dataLen, $newSizes['files/container']);
|
|
|
|
$this->assertEquals($initialSizes['files/container/shareddir'] + $dataLen, $newSizes['files/container/shareddir']);
|
|
|
|
$this->assertEquals($initialSizes['files/container/shareddir/subdir'] + $dataLen, $newSizes['files/container/shareddir/subdir']);
|
|
|
|
|
|
|
|
// no more updates
|
2014-04-08 21:57:07 +04:00
|
|
|
$result = $this->sharedStorage->getWatcher()->checkUpdate('subdir');
|
2013-11-05 22:30:52 +04:00
|
|
|
|
|
|
|
$this->assertFalse($result);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the sizes of the path and its parent dirs in a hash
|
|
|
|
* where the key is the path and the value is the size.
|
2014-02-06 19:30:58 +04:00
|
|
|
* @param string $path
|
2013-11-05 22:30:52 +04:00
|
|
|
*/
|
|
|
|
function getOwnerDirSizes($path) {
|
|
|
|
$result = array();
|
|
|
|
|
|
|
|
while ($path != '' && $path != '' && $path != '.') {
|
|
|
|
$cachedData = $this->ownerCache->get($path);
|
|
|
|
$result[$path] = $cachedData['size'];
|
|
|
|
$path = dirname($path);
|
|
|
|
}
|
|
|
|
$cachedData = $this->ownerCache->get('');
|
|
|
|
$result[''] = $cachedData['size'];
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
}
|