2012-11-08 20:12:40 +00: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 13:18:57 +00:00
|
|
|
use OC\Files\Storage\Temporary;
|
2012-11-08 20:12:40 +00: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 14:08:12 +00:00
|
|
|
private $stateFilesEncryption;
|
|
|
|
|
2012-11-08 20:12:40 +00:00
|
|
|
/**
|
|
|
|
* @var \OC\Files\Cache\Cache $cache
|
|
|
|
*/
|
|
|
|
private $cache;
|
|
|
|
|
|
|
|
private static $user;
|
|
|
|
|
|
|
|
public function setUp() {
|
2013-10-29 14:08:12 +00: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-08 20:12:40 +00: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 14:56:48 +00:00
|
|
|
\OC\Files\Filesystem::tearDown();
|
2012-11-08 20:12:40 +00:00
|
|
|
if (!self::$user) {
|
2013-04-25 14:56:48 +00:00
|
|
|
self::$user = uniqid();
|
2012-11-08 20:12:40 +00:00
|
|
|
}
|
2013-10-29 14:08:12 +00:00
|
|
|
|
|
|
|
\OC_User::createUser(self::$user, 'password');
|
|
|
|
\OC_User::setUserId(self::$user);
|
|
|
|
|
2013-04-25 14:56:48 +00:00
|
|
|
\OC\Files\Filesystem::init(self::$user, '/' . self::$user . '/files');
|
2012-11-08 20:12:40 +00:00
|
|
|
|
|
|
|
Filesystem::clearMounts();
|
|
|
|
Filesystem::mount($this->storage, array(), '/' . self::$user . '/files');
|
|
|
|
|
2013-03-08 18:08:07 +00:00
|
|
|
\OC_Hook::clear('OC_Filesystem');
|
|
|
|
|
2012-11-08 20:12:40 +00: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 19:32:00 +00:00
|
|
|
\OC_Hook::connect('OC_Filesystem', 'post_touch', '\OC\Files\Cache\Updater', 'touchHook');
|
2012-11-08 20:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function tearDown() {
|
2013-01-30 22:15:28 +00:00
|
|
|
if ($this->cache) {
|
2012-11-22 12:14:39 +00:00
|
|
|
$this->cache->clear();
|
|
|
|
}
|
2013-10-29 14:08:12 +00:00
|
|
|
$result = \OC_User::deleteUser(self::$user);
|
|
|
|
$this->assertTrue($result);
|
2012-11-08 20:12:40 +00:00
|
|
|
Filesystem::tearDown();
|
2013-10-29 14:08:12 +00:00
|
|
|
// reset app files_encryption
|
|
|
|
if ($this->stateFilesEncryption) {
|
|
|
|
\OC_App::enable('files_encryption');
|
|
|
|
}
|
2012-11-08 20:12:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testWrite() {
|
|
|
|
$textSize = strlen("dummy file data\n");
|
|
|
|
$imageSize = filesize(\OC::$SERVERROOT . '/core/img/logo.png');
|
2014-01-14 14:13:21 +00:00
|
|
|
$this->cache->put('foo.txt', array('mtime' => 100, 'storage_mtime' => 150));
|
2012-12-31 23:16:44 +00:00
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $rootCachedData['size']);
|
2012-11-08 20:12:40 +00:00
|
|
|
|
2012-12-31 23:16:44 +00:00
|
|
|
$fooCachedData = $this->cache->get('foo.txt');
|
2012-11-08 20:12:40 +00:00
|
|
|
Filesystem::file_put_contents('foo.txt', 'asd');
|
|
|
|
$cachedData = $this->cache->get('foo.txt');
|
|
|
|
$this->assertEquals(3, $cachedData['size']);
|
2012-12-31 23:16:44 +00:00
|
|
|
$this->assertNotEquals($fooCachedData['etag'], $cachedData['etag']);
|
2012-11-08 20:12:40 +00:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(2 * $textSize + $imageSize + 3, $cachedData['size']);
|
2012-12-31 23:16:44 +00:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
|
|
|
$rootCachedData = $cachedData;
|
2012-11-08 20:12:40 +00: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 05:43:43 +00:00
|
|
|
$mtime = $cachedData['mtime'];
|
2012-11-08 20:12:40 +00:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(2 * $textSize + $imageSize + 2 * 3, $cachedData['size']);
|
2012-12-31 23:16:44 +00:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2013-01-30 22:15:28 +00:00
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $mtime);
|
2012-11-08 20:12:40 +00:00
|
|
|
}
|
|
|
|
|
2013-06-12 19:32:00 +00: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-08 20:12:40 +00:00
|
|
|
public function testDelete() {
|
|
|
|
$textSize = strlen("dummy file data\n");
|
|
|
|
$imageSize = filesize(\OC::$SERVERROOT . '/core/img/logo.png');
|
2012-12-31 23:16:44 +00:00
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $rootCachedData['size']);
|
2012-11-08 20:12:40 +00:00
|
|
|
|
|
|
|
$this->assertTrue($this->cache->inCache('foo.txt'));
|
2013-06-12 19:32:00 +00:00
|
|
|
Filesystem::unlink('foo.txt');
|
2012-11-08 20:12:40 +00:00
|
|
|
$this->assertFalse($this->cache->inCache('foo.txt'));
|
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(2 * $textSize + $imageSize, $cachedData['size']);
|
2012-12-31 23:16:44 +00:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2013-01-22 05:43:43 +00:00
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $cachedData['mtime']);
|
2012-12-31 23:16:44 +00:00
|
|
|
$rootCachedData = $cachedData;
|
2012-12-11 00:25:21 +00:00
|
|
|
|
|
|
|
Filesystem::mkdir('bar_folder');
|
|
|
|
$this->assertTrue($this->cache->inCache('bar_folder'));
|
2012-12-31 23:16:44 +00:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
|
|
|
$rootCachedData = $cachedData;
|
2012-12-11 00:25:21 +00:00
|
|
|
Filesystem::rmdir('bar_folder');
|
|
|
|
$this->assertFalse($this->cache->inCache('bar_folder'));
|
2012-12-31 23:16:44 +00:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2013-01-22 05:43:43 +00:00
|
|
|
$this->assertGreaterThanOrEqual($rootCachedData['mtime'], $cachedData['mtime']);
|
2012-11-08 20:12:40 +00:00
|
|
|
}
|
|
|
|
|
2013-06-12 19:32:00 +00: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-08 20:12:40 +00:00
|
|
|
public function testRename() {
|
|
|
|
$textSize = strlen("dummy file data\n");
|
|
|
|
$imageSize = filesize(\OC::$SERVERROOT . '/core/img/logo.png');
|
2012-12-31 23:16:44 +00:00
|
|
|
$rootCachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $rootCachedData['size']);
|
2012-11-08 20:12:40 +00:00
|
|
|
|
|
|
|
$this->assertTrue($this->cache->inCache('foo.txt'));
|
2012-12-31 23:16:44 +00:00
|
|
|
$fooCachedData = $this->cache->get('foo.txt');
|
2012-11-08 20:12:40 +00: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 15:36:03 +00:00
|
|
|
$cachedData = $this->cache->get('bar.txt');
|
2013-03-08 18:08:07 +00:00
|
|
|
$this->assertEquals($fooCachedData['fileid'], $cachedData['fileid']);
|
2013-01-22 05:43:43 +00:00
|
|
|
$mtime = $cachedData['mtime'];
|
2012-11-08 20:12:40 +00:00
|
|
|
$cachedData = $this->cache->get('');
|
|
|
|
$this->assertEquals(3 * $textSize + $imageSize, $cachedData['size']);
|
2012-12-31 23:16:44 +00:00
|
|
|
$this->assertNotEquals($rootCachedData['etag'], $cachedData['etag']);
|
2012-11-08 20:12:40 +00:00
|
|
|
}
|
2013-06-12 19:32:00 +00:00
|
|
|
|
2013-11-27 17:48:24 +00: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 19:32:00 +00: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-01 20:02:21 +00:00
|
|
|
// rename can cause mtime change - invalid assert
|
|
|
|
// $this->assertEquals($mtime, $cachedData['mtime']);
|
2013-06-12 19:32:00 +00:00
|
|
|
|
|
|
|
$cachedData = $this->cache->get('folder');
|
|
|
|
$this->assertNotEquals($folderCachedData['etag'], $cachedData['etag']);
|
2013-07-01 20:02:21 +00:00
|
|
|
// rename can cause mtime change - invalid assert
|
|
|
|
// $this->assertEquals($mtime, $cachedData['mtime']);
|
2013-06-12 19:32:00 +00: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 13:18:57 +00: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-08 20:12:40 +00:00
|
|
|
}
|