2012-11-09 00:12:40 +04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2012 Robin Appelman <icewind@owncloud.com>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Test\Files\Cache;
|
|
|
|
|
|
|
|
use \OC\Files\Filesystem as Filesystem;
|
2013-10-29 17:18:57 +04:00
|
|
|
use OC\Files\Storage\Temporary;
|
2012-11-09 00:12:40 +04:00
|
|
|
|
|
|
|
class Updater extends \PHPUnit_Framework_TestCase {
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Storage\Storage $storage
|
|
|
|
*/
|
|
|
|
private $storage;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Cache\Scanner $scanner
|
|
|
|
*/
|
|
|
|
private $scanner;
|
|
|
|
|
2013-10-29 18:08:12 +04:00
|
|
|
private $stateFilesEncryption;
|
|
|
|
|
2012-11-09 00:12:40 +04:00
|
|
|
/**
|
|
|
|
* @var \OC\Files\Cache\Cache $cache
|
|
|
|
*/
|
|
|
|
private $cache;
|
|
|
|
|
|
|
|
private static $user;
|
|
|
|
|
|
|
|
public function setUp() {
|
2013-10-29 18:08:12 +04:00
|
|
|
|
|
|
|
// remember files_encryption state
|
|
|
|
$this->stateFilesEncryption = \OC_App::isEnabled('files_encryption');
|
|
|
|
// we want to tests with the encryption app disabled
|
|
|
|
\OC_App::disable('files_encryption');
|
|
|
|
|
2012-11-09 00:12:40 +04:00
|
|
|
$this->storage = new \OC\Files\Storage\Temporary(array());
|
|
|
|
$textData = "dummy file data\n";
|
|
|
|
$imgData = file_get_contents(\OC::$SERVERROOT . '/core/img/logo.png');
|
|
|
|
$this->storage->mkdir('folder');
|
|
|
|
$this->storage->file_put_contents('foo.txt', $textData);
|
|
|
|
$this->storage->file_put_contents('foo.png', $imgData);
|
|
|
|
$this->storage->file_put_contents('folder/bar.txt', $textData);
|
|
|
|
$this->storage->file_put_contents('folder/bar2.txt', $textData);
|
|
|
|
|
|
|
|
$this->scanner = $this->storage->getScanner();
|
|
|
|
$this->scanner->scan('');
|
|
|
|
$this->cache = $this->storage->getCache();
|
|
|
|
|
2013-04-25 18:56:48 +04:00
|
|
|
\OC\Files\Filesystem::tearDown();
|
2012-11-09 00:12:40 +04:00
|
|
|
if (!self::$user) {
|
2013-04-25 18:56:48 +04:00
|
|
|
self::$user = uniqid();
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|
2013-10-29 18:08:12 +04:00
|
|
|
|
|
|
|
\OC_User::createUser(self::$user, 'password');
|
|
|
|
\OC_User::setUserId(self::$user);
|
|
|
|
|
2013-04-25 18:56:48 +04:00
|
|
|
\OC\Files\Filesystem::init(self::$user, '/' . self::$user . '/files');
|
2012-11-09 00:12:40 +04:00
|
|
|
|
|
|
|
Filesystem::clearMounts();
|
|
|
|
Filesystem::mount($this->storage, array(), '/' . self::$user . '/files');
|
|
|
|
|
2013-03-08 22:08:07 +04:00
|
|
|
\OC_Hook::clear('OC_Filesystem');
|
|
|
|
|
2012-11-09 00:12:40 +04:00
|
|
|
\OC_Hook::connect('OC_Filesystem', 'post_write', '\OC\Files\Cache\Updater', 'writeHook');
|
|
|
|
\OC_Hook::connect('OC_Filesystem', 'post_delete', '\OC\Files\Cache\Updater', 'deleteHook');
|
|
|
|
\OC_Hook::connect('OC_Filesystem', 'post_rename', '\OC\Files\Cache\Updater', 'renameHook');
|
2013-06-12 23:32:00 +04:00
|
|
|
\OC_Hook::connect('OC_Filesystem', 'post_touch', '\OC\Files\Cache\Updater', 'touchHook');
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function tearDown() {
|
2013-01-31 02:15:28 +04:00
|
|
|
if ($this->cache) {
|
2012-11-22 16:14:39 +04:00
|
|
|
$this->cache->clear();
|
|
|
|
}
|
2013-10-29 18:08:12 +04:00
|
|
|
$result = \OC_User::deleteUser(self::$user);
|
|
|
|
$this->assertTrue($result);
|
2012-11-09 00:12:40 +04:00
|
|
|
Filesystem::tearDown();
|
2013-10-29 18:08:12 +04:00
|
|
|
// reset app files_encryption
|
|
|
|
if ($this->stateFilesEncryption) {
|
|
|
|
\OC_App::enable('files_encryption');
|
|
|
|
}
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testWrite() {
|
|
|
|
$textSize = strlen("dummy file data\n");
|
|
|
|
$imageSize = filesize(\OC::$SERVERROOT . '/core/img/logo.png');
|
2013-06-19 02:26:47 +04:00
|
|
|
$this->cache->put('foo.txt', array('mtime' => 100));
|
2013-01-01 03:16:44 +04:00
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $rootCachedData['size']);
|
2012-11-09 00:12:40 +04:00
|
|
|
|
2013-01-01 03:16:44 +04:00
|
|
|
$fooCachedData = $this->cache->get('foo.txt');
|
2012-11-09 00:12:40 +04:00
|
|
|
Filesystem::file_put_contents('foo.txt', 'asd');
|
|
|
|
$cachedData = $this->cache->get('foo.txt');
|
|
|
|
$this->assertEquals(3, $cachedData['size']);
|
2013-01-01 03:16:44 +04:00
|
|
|
$this->assertNotEquals($fooCachedData['etag'], $cachedData['etag']);
|
2012-11-09 00:12:40 +04:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(2 * $textSize + $imageSize + 3, $cachedData['size']);
|
2013-01-01 03:16:44 +04:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
|
|
|
$rootCachedData = $cachedData;
|
2012-11-09 00:12:40 +04:00
|
|
|
|
|
|
|
$this->assertFalse($this->cache->inCache('bar.txt'));
|
|
|
|
Filesystem::file_put_contents('bar.txt', 'asd');
|
|
|
|
$this->assertTrue($this->cache->inCache('bar.txt'));
|
|
|
|
$cachedData = $this->cache->get('bar.txt');
|
|
|
|
$this->assertEquals(3, $cachedData['size']);
|
2013-01-22 09:43:43 +04:00
|
|
|
$mtime = $cachedData['mtime'];
|
2012-11-09 00:12:40 +04:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(2 * $textSize + $imageSize + 2 * 3, $cachedData['size']);
|
2013-01-01 03:16:44 +04:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2013-01-31 02:15:28 +04:00
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $mtime);
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|
|
|
|
|
2013-06-12 23:32:00 +04:00
|
|
|
public function testWriteWithMountPoints() {
|
|
|
|
$storage2 = new \OC\Files\Storage\Temporary(array());
|
|
|
|
$cache2 = $storage2->getCache();
|
|
|
|
Filesystem::mount($storage2, array(), '/' . self::$user . '/files/folder/substorage');
|
|
|
|
$folderCachedData = $this->cache->get('folder');
|
|
|
|
$substorageCachedData = $cache2->get('');
|
|
|
|
Filesystem::file_put_contents('folder/substorage/foo.txt', 'asd');
|
|
|
|
$this->assertTrue($cache2->inCache('foo.txt'));
|
|
|
|
$cachedData = $cache2->get('foo.txt');
|
|
|
|
$this->assertEquals(3, $cachedData['size']);
|
|
|
|
$mtime = $cachedData['mtime'];
|
|
|
|
|
|
|
|
$cachedData = $cache2->get('');
|
|
|
|
$this->assertNotEquals($substorageCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertEquals($mtime, $cachedData['mtime']);
|
|
|
|
|
|
|
|
$cachedData = $this->cache->get('folder');
|
|
|
|
$this->assertNotEquals($folderCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertEquals($mtime, $cachedData['mtime']);
|
|
|
|
}
|
|
|
|
|
2012-11-09 00:12:40 +04:00
|
|
|
public function testDelete() {
|
|
|
|
$textSize = strlen("dummy file data\n");
|
|
|
|
$imageSize = filesize(\OC::$SERVERROOT . '/core/img/logo.png');
|
2013-01-01 03:16:44 +04:00
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $rootCachedData['size']);
|
2012-11-09 00:12:40 +04:00
|
|
|
|
|
|
|
$this->assertTrue($this->cache->inCache('foo.txt'));
|
2013-06-12 23:32:00 +04:00
|
|
|
Filesystem::unlink('foo.txt');
|
2012-11-09 00:12:40 +04:00
|
|
|
$this->assertFalse($this->cache->inCache('foo.txt'));
|
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(2 * $textSize + $imageSize, $cachedData['size']);
|
2013-01-01 03:16:44 +04:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2013-01-22 09:43:43 +04:00
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $cachedData['mtime']);
|
2013-01-01 03:16:44 +04:00
|
|
|
$rootCachedData = $cachedData;
|
2012-12-11 04:25:21 +04:00
|
|
|
|
|
|
|
Filesystem::mkdir('bar_folder');
|
|
|
|
$this->assertTrue($this->cache->inCache('bar_folder'));
|
2013-01-01 03:16:44 +04:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
|
|
|
$rootCachedData = $cachedData;
|
2012-12-11 04:25:21 +04:00
|
|
|
Filesystem::rmdir('bar_folder');
|
|
|
|
$this->assertFalse($this->cache->inCache('bar_folder'));
|
2013-01-01 03:16:44 +04:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2013-01-22 09:43:43 +04:00
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $cachedData['mtime']);
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|
|
|
|
|
2013-06-12 23:32:00 +04:00
|
|
|
public function testDeleteWithMountPoints() {
|
|
|
|
$storage2 = new \OC\Files\Storage\Temporary(array());
|
|
|
|
$cache2 = $storage2->getCache();
|
|
|
|
Filesystem::mount($storage2, array(), '/' . self::$user . '/files/folder/substorage');
|
|
|
|
Filesystem::file_put_contents('folder/substorage/foo.txt', 'asd');
|
|
|
|
$this->assertTrue($cache2->inCache('foo.txt'));
|
|
|
|
$folderCachedData = $this->cache->get('folder');
|
|
|
|
$substorageCachedData = $cache2->get('');
|
|
|
|
Filesystem::unlink('folder/substorage/foo.txt');
|
|
|
|
$this->assertFalse($cache2->inCache('foo.txt'));
|
|
|
|
|
|
|
|
$cachedData = $cache2->get('');
|
|
|
|
$this->assertNotEquals($substorageCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertGreaterThanOrEqual($substorageCachedData['mtime'], $cachedData['mtime']);
|
|
|
|
|
|
|
|
$cachedData = $this->cache->get('folder');
|
|
|
|
$this->assertNotEquals($folderCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertGreaterThanOrEqual($folderCachedData['mtime'], $cachedData['mtime']);
|
|
|
|
}
|
|
|
|
|
2012-11-09 00:12:40 +04:00
|
|
|
public function testRename() {
|
|
|
|
$textSize = strlen("dummy file data\n");
|
|
|
|
$imageSize = filesize(\OC::$SERVERROOT . '/core/img/logo.png');
|
2013-01-01 03:16:44 +04:00
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $rootCachedData['size']);
|
2012-11-09 00:12:40 +04:00
|
|
|
|
|
|
|
$this->assertTrue($this->cache->inCache('foo.txt'));
|
2013-01-01 03:16:44 +04:00
|
|
|
$fooCachedData = $this->cache->get('foo.txt');
|
2012-11-09 00:12:40 +04:00
|
|
|
$this->assertFalse($this->cache->inCache('bar.txt'));
|
|
|
|
Filesystem::rename('foo.txt', 'bar.txt');
|
|
|
|
$this->assertFalse($this->cache->inCache('foo.txt'));
|
|
|
|
$this->assertTrue($this->cache->inCache('bar.txt'));
|
2013-01-22 19:36:03 +04:00
|
|
|
$cachedData = $this->cache->get('bar.txt');
|
2013-03-08 22:08:07 +04:00
|
|
|
$this->assertEquals($fooCachedData['fileid'], $cachedData['fileid']);
|
2013-01-22 09:43:43 +04:00
|
|
|
$mtime = $cachedData['mtime'];
|
2012-11-09 00:12:40 +04:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $cachedData['size']);
|
2013-01-01 03:16:44 +04:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|
2013-06-12 23:32:00 +04:00
|
|
|
|
2013-11-27 21:48:24 +04:00
|
|
|
public function testRenameExtension() {
|
|
|
|
$fooCachedData = $this->cache->get('foo.txt');
|
|
|
|
$this->assertEquals('text/plain', $fooCachedData['mimetype']);
|
|
|
|
Filesystem::rename('foo.txt', 'foo.abcd');
|
|
|
|
$fooCachedData = $this->cache->get('foo.abcd');
|
|
|
|
$this->assertEquals('application/octet-stream', $fooCachedData['mimetype']);
|
|
|
|
}
|
|
|
|
|
2013-06-12 23:32:00 +04:00
|
|
|
public function testRenameWithMountPoints() {
|
|
|
|
$storage2 = new \OC\Files\Storage\Temporary(array());
|
|
|
|
$cache2 = $storage2->getCache();
|
|
|
|
Filesystem::mount($storage2, array(), '/' . self::$user . '/files/folder/substorage');
|
|
|
|
Filesystem::file_put_contents('folder/substorage/foo.txt', 'asd');
|
|
|
|
$this->assertTrue($cache2->inCache('foo.txt'));
|
|
|
|
$folderCachedData = $this->cache->get('folder');
|
|
|
|
$substorageCachedData = $cache2->get('');
|
|
|
|
$fooCachedData = $cache2->get('foo.txt');
|
|
|
|
Filesystem::rename('folder/substorage/foo.txt', 'folder/substorage/bar.txt');
|
|
|
|
$this->assertFalse($cache2->inCache('foo.txt'));
|
|
|
|
$this->assertTrue($cache2->inCache('bar.txt'));
|
|
|
|
$cachedData = $cache2->get('bar.txt');
|
|
|
|
$this->assertEquals($fooCachedData['fileid'], $cachedData['fileid']);
|
|
|
|
$mtime = $cachedData['mtime'];
|
|
|
|
|
|
|
|
$cachedData = $cache2->get('');
|
|
|
|
$this->assertNotEquals($substorageCachedData['etag'], $cachedData['etag']);
|
2013-07-02 00:02:21 +04:00
|
|
|
// rename can cause mtime change - invalid assert
|
|
|
|
// $this->assertEquals($mtime, $cachedData['mtime']);
|
2013-06-12 23:32:00 +04:00
|
|
|
|
|
|
|
$cachedData = $this->cache->get('folder');
|
|
|
|
$this->assertNotEquals($folderCachedData['etag'], $cachedData['etag']);
|
2013-07-02 00:02:21 +04:00
|
|
|
// rename can cause mtime change - invalid assert
|
|
|
|
// $this->assertEquals($mtime, $cachedData['mtime']);
|
2013-06-12 23:32:00 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testTouch() {
|
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$fooCachedData = $this->cache->get('foo.txt');
|
|
|
|
Filesystem::touch('foo.txt');
|
|
|
|
$cachedData = $this->cache->get('foo.txt');
|
|
|
|
$this->assertNotEquals($fooCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertGreaterThanOrEqual($fooCachedData['mtime'], $cachedData['mtime']);
|
|
|
|
|
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $cachedData['mtime']);
|
|
|
|
$rootCachedData = $cachedData;
|
|
|
|
|
|
|
|
$time = 1371006070;
|
|
|
|
$barCachedData = $this->cache->get('folder/bar.txt');
|
|
|
|
$folderCachedData = $this->cache->get('folder');
|
|
|
|
Filesystem::touch('folder/bar.txt', $time);
|
|
|
|
$cachedData = $this->cache->get('folder/bar.txt');
|
|
|
|
$this->assertNotEquals($barCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertEquals($time, $cachedData['mtime']);
|
|
|
|
|
|
|
|
$cachedData = $this->cache->get('folder');
|
|
|
|
$this->assertNotEquals($folderCachedData['etag'], $cachedData['etag']);
|
|
|
|
|
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertEquals($time, $cachedData['mtime']);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testTouchWithMountPoints() {
|
|
|
|
$storage2 = new \OC\Files\Storage\Temporary(array());
|
|
|
|
$cache2 = $storage2->getCache();
|
|
|
|
Filesystem::mount($storage2, array(), '/' . self::$user . '/files/folder/substorage');
|
|
|
|
Filesystem::file_put_contents('folder/substorage/foo.txt', 'asd');
|
|
|
|
$this->assertTrue($cache2->inCache('foo.txt'));
|
|
|
|
$folderCachedData = $this->cache->get('folder');
|
|
|
|
$substorageCachedData = $cache2->get('');
|
|
|
|
$fooCachedData = $cache2->get('foo.txt');
|
|
|
|
$cachedData = $cache2->get('foo.txt');
|
|
|
|
$time = 1371006070;
|
|
|
|
Filesystem::touch('folder/substorage/foo.txt', $time);
|
|
|
|
$cachedData = $cache2->get('foo.txt');
|
|
|
|
$this->assertNotEquals($fooCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertEquals($time, $cachedData['mtime']);
|
|
|
|
|
|
|
|
$cachedData = $cache2->get('');
|
|
|
|
$this->assertNotEquals($substorageCachedData['etag'], $cachedData['etag']);
|
|
|
|
|
|
|
|
$cachedData = $this->cache->get('folder');
|
|
|
|
$this->assertNotEquals($folderCachedData['etag'], $cachedData['etag']);
|
|
|
|
$this->assertEquals($time, $cachedData['mtime']);
|
|
|
|
}
|
|
|
|
|
2013-10-29 17:18:57 +04:00
|
|
|
public function testUpdatePermissionsOnRescanOnlyForUpdatedFile() {
|
|
|
|
$permissionsCache = $this->storage->getPermissionsCache();
|
|
|
|
$scanner = $this->storage->getScanner();
|
|
|
|
$scanner->scan('');
|
|
|
|
$cache = $this->storage->getCache();
|
|
|
|
$loggedInUser = \OC_User::getUser();
|
|
|
|
\OC_User::setUserId(self::$user);
|
|
|
|
FileSystem::getDirectoryContent('/');
|
|
|
|
$past = time() - 600;
|
|
|
|
$cache->put('', array('storage_mtime' => $past));
|
|
|
|
|
|
|
|
$this->assertNotEquals(-1, $permissionsCache->get($cache->getId('foo.txt'), self::$user));
|
|
|
|
$this->assertNotEquals(-1, $permissionsCache->get($cache->getId('foo.png'), self::$user));
|
|
|
|
|
|
|
|
$permissionsCache->set($cache->getId('foo.png'), self::$user, 15);
|
|
|
|
FileSystem::file_put_contents('/foo.txt', 'asd');
|
|
|
|
|
|
|
|
$this->assertEquals(-1, $permissionsCache->get($cache->getId('foo.txt'), self::$user));
|
|
|
|
$this->assertEquals(15, $permissionsCache->get($cache->getId('foo.png'), self::$user));
|
|
|
|
|
|
|
|
FileSystem::getDirectoryContent('/');
|
|
|
|
|
|
|
|
$this->assertEquals(15, $permissionsCache->get($cache->getId('foo.png'), self::$user));
|
|
|
|
|
|
|
|
FileSystem::file_put_contents('/qwerty.txt', 'asd');
|
|
|
|
FileSystem::getDirectoryContent('/');
|
|
|
|
|
|
|
|
$this->assertEquals(15, $permissionsCache->get($cache->getId('foo.png'), self::$user));
|
|
|
|
|
|
|
|
\OC_User::setUserId($loggedInUser);
|
|
|
|
}
|
2012-11-09 00:12:40 +04:00
|
|
|
}
|