parent
0c0829fbc7
commit
d8d6368dd7
@ -0,0 +1,87 @@ |
||||
<?php |
||||
/** |
||||
* @author Robin Appelman <icewind@owncloud.com> |
||||
* |
||||
* @copyright Copyright (c) 2016, ownCloud, Inc. |
||||
* @license AGPL-3.0 |
||||
* |
||||
* 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. |
||||
* |
||||
* 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, version 3, |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/> |
||||
* |
||||
*/ |
||||
|
||||
namespace OC\Cache; |
||||
|
||||
use OCP\ICache; |
||||
|
||||
/** |
||||
* In-memory cache with a capacity limit to keep memory usage in check |
||||
* |
||||
* Uses a simple FIFO expiry mechanism |
||||
*/ |
||||
class CappedMemoryCache implements ICache, \ArrayAccess { |
||||
|
||||
private $capacity; |
||||
private $cache = []; |
||||
|
||||
public function __construct($capacity = 512) { |
||||
$this->capacity = $capacity; |
||||
} |
||||
|
||||
public function hasKey($key) { |
||||
return isset($this->cache[$key]); |
||||
} |
||||
|
||||
public function get($key) { |
||||
return isset($this->cache[$key]) ? $this->cache[$key] : null; |
||||
} |
||||
|
||||
public function set($key, $value, $ttl = 0) { |
||||
$this->cache[$key] = $value; |
||||
$this->garbageCollect(); |
||||
} |
||||
|
||||
public function remove($key) { |
||||
unset($this->cache[$key]); |
||||
return true; |
||||
} |
||||
|
||||
public function clear($prefix = '') { |
||||
$this->cache = []; |
||||
return true; |
||||
} |
||||
|
||||
public function offsetExists($offset) { |
||||
return $this->hasKey($offset); |
||||
} |
||||
|
||||
public function offsetGet($offset) { |
||||
return $this->get($offset); |
||||
} |
||||
|
||||
public function offsetSet($offset, $value) { |
||||
$this->set($offset, $value); |
||||
} |
||||
|
||||
public function offsetUnset($offset) { |
||||
$this->remove($offset); |
||||
} |
||||
|
||||
|
||||
private function garbageCollect() { |
||||
while (count($this->cache) > $this->capacity) { |
||||
reset($this->cache); |
||||
$key = key($this->cache); |
||||
$this->remove($key); |
||||
} |
||||
} |
||||
} |
||||
@ -0,0 +1,67 @@ |
||||
<?php |
||||
/** |
||||
* ownCloud |
||||
* |
||||
* @author Robin Appelman |
||||
* @copyright 2016 Robin Appelman icewind@owncloud.com |
||||
* |
||||
* This library is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE |
||||
* License as published by the Free Software Foundation; either |
||||
* version 3 of the License, or any later version. |
||||
* |
||||
* This library 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 library. If not, see <http://www.gnu.org/licenses/>. |
||||
* |
||||
*/ |
||||
|
||||
namespace Test\Cache; |
||||
|
||||
/** |
||||
* Class FileCache |
||||
* |
||||
* @group DB |
||||
* |
||||
* @package Test\Cache |
||||
*/ |
||||
class CappedMemoryCache extends \Test_Cache { |
||||
public function setUp() { |
||||
parent::setUp(); |
||||
$this->instance = new \OC\Cache\CappedMemoryCache(); |
||||
} |
||||
|
||||
public function testSetOverCap() { |
||||
$instance = new \OC\Cache\CappedMemoryCache(3); |
||||
|
||||
$instance->set('1', 'a'); |
||||
$instance->set('2', 'b'); |
||||
$instance->set('3', 'c'); |
||||
$instance->set('4', 'd'); |
||||
$instance->set('5', 'e'); |
||||
|
||||
$this->assertFalse($instance->hasKey('1')); |
||||
$this->assertFalse($instance->hasKey('2')); |
||||
$this->assertTrue($instance->hasKey('3')); |
||||
$this->assertTrue($instance->hasKey('4')); |
||||
$this->assertTrue($instance->hasKey('5')); |
||||
} |
||||
|
||||
function testClear() { |
||||
$value = 'ipsum lorum'; |
||||
$this->instance->set('1_value1', $value); |
||||
$this->instance->set('1_value2', $value); |
||||
$this->instance->set('2_value1', $value); |
||||
$this->instance->set('3_value1', $value); |
||||
|
||||
$this->assertTrue($this->instance->clear()); |
||||
$this->assertFalse($this->instance->hasKey('1_value1')); |
||||
$this->assertFalse($this->instance->hasKey('1_value2')); |
||||
$this->assertFalse($this->instance->hasKey('2_value1')); |
||||
$this->assertFalse($this->instance->hasKey('3_value1')); |
||||
} |
||||
} |
||||
Loading…
Reference in new issue