Renamed old Caching2BlockStore to new CachingBlockStore
This commit is contained in:
parent
248fd0f5cc
commit
9fa6b041eb
@ -7,7 +7,7 @@ using std::lock_guard;
|
|||||||
using std::pair;
|
using std::pair;
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
constexpr uint32_t Cache::MAX_ENTRIES;
|
constexpr uint32_t Cache::MAX_ENTRIES;
|
||||||
|
|
@ -1,15 +1,15 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#ifndef MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING2_CACHE_H_
|
#ifndef MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING_CACHE_H_
|
||||||
#define MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING2_CACHE_H_
|
#define MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING_CACHE_H_
|
||||||
|
|
||||||
#include "../../interface/Block.h"
|
|
||||||
#include "CacheEntry.h"
|
#include "CacheEntry.h"
|
||||||
#include "QueueMap.h"
|
#include "QueueMap.h"
|
||||||
|
#include "../../interface/Block.h"
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
//TODO Test
|
//TODO Test
|
||||||
//TODO Also throw blocks out after a timeout
|
//TODO Also throw blocks out after a timeout
|
@ -1,6 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#ifndef MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING2_CACHEENTRY_H_
|
#ifndef MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING_CACHEENTRY_H_
|
||||||
#define MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING2_CACHEENTRY_H_
|
#define MESSMER_BLOCKSTORE_IMPLEMENTATIONS_CACHING_CACHEENTRY_H_
|
||||||
|
|
||||||
#include <ctime>
|
#include <ctime>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
class Block;
|
class Block;
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
class CacheEntry {
|
class CacheEntry {
|
||||||
public:
|
public:
|
@ -1,13 +1,13 @@
|
|||||||
#include "CachedBlock.h"
|
#include "CachedBlock.h"
|
||||||
#include "Caching2BlockStore.h"
|
#include "CachingBlockStore.h"
|
||||||
|
|
||||||
using std::unique_ptr;
|
using std::unique_ptr;
|
||||||
using std::make_unique;
|
using std::make_unique;
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
CachedBlock::CachedBlock(std::unique_ptr<Block> baseBlock, Caching2BlockStore *blockStore)
|
CachedBlock::CachedBlock(std::unique_ptr<Block> baseBlock, CachingBlockStore *blockStore)
|
||||||
:Block(baseBlock->key()),
|
:Block(baseBlock->key()),
|
||||||
_blockStore(blockStore),
|
_blockStore(blockStore),
|
||||||
_baseBlock(std::move(baseBlock)) {
|
_baseBlock(std::move(baseBlock)) {
|
@ -8,13 +8,13 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
class Caching2BlockStore;
|
class CachingBlockStore;
|
||||||
|
|
||||||
class CachedBlock: public Block {
|
class CachedBlock: public Block {
|
||||||
public:
|
public:
|
||||||
//TODO Storing key twice (in parent class and in object pointed to). Once would be enough.
|
//TODO Storing key twice (in parent class and in object pointed to). Once would be enough.
|
||||||
CachedBlock(std::unique_ptr<Block> baseBlock, Caching2BlockStore *blockStore);
|
CachedBlock(std::unique_ptr<Block> baseBlock, CachingBlockStore *blockStore);
|
||||||
virtual ~CachedBlock();
|
virtual ~CachedBlock();
|
||||||
|
|
||||||
const void *data() const override;
|
const void *data() const override;
|
||||||
@ -27,7 +27,7 @@ public:
|
|||||||
std::unique_ptr<Block> releaseBlock();
|
std::unique_ptr<Block> releaseBlock();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Caching2BlockStore *_blockStore;
|
CachingBlockStore *_blockStore;
|
||||||
std::unique_ptr<Block> _baseBlock;
|
std::unique_ptr<Block> _baseBlock;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(CachedBlock);
|
DISALLOW_COPY_AND_ASSIGN(CachedBlock);
|
@ -1,5 +1,5 @@
|
|||||||
#include "Caching2BlockStore.h"
|
|
||||||
#include "CachedBlock.h"
|
#include "CachedBlock.h"
|
||||||
|
#include "CachingBlockStore.h"
|
||||||
#include "../../interface/Block.h"
|
#include "../../interface/Block.h"
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
@ -10,13 +10,13 @@ using std::make_unique;
|
|||||||
using cpputils::dynamic_pointer_move;
|
using cpputils::dynamic_pointer_move;
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
Caching2BlockStore::Caching2BlockStore(std::unique_ptr<BlockStore> baseBlockStore)
|
CachingBlockStore::CachingBlockStore(std::unique_ptr<BlockStore> baseBlockStore)
|
||||||
:_baseBlockStore(std::move(baseBlockStore)) {
|
:_baseBlockStore(std::move(baseBlockStore)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
unique_ptr<Block> Caching2BlockStore::create(size_t size) {
|
unique_ptr<Block> CachingBlockStore::create(size_t size) {
|
||||||
//TODO Also cache this and only write back in the destructor?
|
//TODO Also cache this and only write back in the destructor?
|
||||||
// When writing back is done efficiently in the base store (e.g. only one safe-to-disk, not one in the create() and then one in the save(), this is not supported by the current BlockStore interface),
|
// When writing back is done efficiently in the base store (e.g. only one safe-to-disk, not one in the create() and then one in the save(), this is not supported by the current BlockStore interface),
|
||||||
// then the base store could actually directly create a block in the create() call, OnDiskBlockStore wouldn't have to avoid file creation in the create() call for performance reasons and I could also adapt the OnDiskBlockStore test cases and remove a lot of flush() calls there because then blocks are loadable directly after the create call() without a flush.
|
// then the base store could actually directly create a block in the create() call, OnDiskBlockStore wouldn't have to avoid file creation in the create() call for performance reasons and I could also adapt the OnDiskBlockStore test cases and remove a lot of flush() calls there because then blocks are loadable directly after the create call() without a flush.
|
||||||
@ -24,7 +24,7 @@ unique_ptr<Block> Caching2BlockStore::create(size_t size) {
|
|||||||
return make_unique<CachedBlock>(_baseBlockStore->create(size), this);
|
return make_unique<CachedBlock>(_baseBlockStore->create(size), this);
|
||||||
}
|
}
|
||||||
|
|
||||||
unique_ptr<Block> Caching2BlockStore::load(const Key &key) {
|
unique_ptr<Block> CachingBlockStore::load(const Key &key) {
|
||||||
auto block = _cache.pop(key);
|
auto block = _cache.pop(key);
|
||||||
if (block.get() != nullptr) {
|
if (block.get() != nullptr) {
|
||||||
return make_unique<CachedBlock>(std::move(block), this);
|
return make_unique<CachedBlock>(std::move(block), this);
|
||||||
@ -36,15 +36,15 @@ unique_ptr<Block> Caching2BlockStore::load(const Key &key) {
|
|||||||
return make_unique<CachedBlock>(std::move(block), this);
|
return make_unique<CachedBlock>(std::move(block), this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Caching2BlockStore::remove(std::unique_ptr<Block> block) {
|
void CachingBlockStore::remove(std::unique_ptr<Block> block) {
|
||||||
return _baseBlockStore->remove(std::move(dynamic_pointer_move<CachedBlock>(block)->releaseBlock()));
|
return _baseBlockStore->remove(std::move(dynamic_pointer_move<CachedBlock>(block)->releaseBlock()));
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t Caching2BlockStore::numBlocks() const {
|
uint64_t CachingBlockStore::numBlocks() const {
|
||||||
return _baseBlockStore->numBlocks();
|
return _baseBlockStore->numBlocks();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Caching2BlockStore::release(unique_ptr<Block> block) {
|
void CachingBlockStore::release(unique_ptr<Block> block) {
|
||||||
_cache.push(std::move(block));
|
_cache.push(std::move(block));
|
||||||
}
|
}
|
||||||
|
|
@ -1,18 +1,18 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#ifndef BLOCKSTORE_IMPLEMENTATIONS_CACHING2_CACHINGBLOCKSTORE_H_
|
#ifndef BLOCKSTORE_IMPLEMENTATIONS_CACHING_CACHINGBLOCKSTORE_H_
|
||||||
#define BLOCKSTORE_IMPLEMENTATIONS_CACHING2_CACHINGBLOCKSTORE_H_
|
#define BLOCKSTORE_IMPLEMENTATIONS_CACHING_CACHINGBLOCKSTORE_H_
|
||||||
|
|
||||||
#include "../../interface/BlockStore.h"
|
|
||||||
#include "Cache.h"
|
#include "Cache.h"
|
||||||
|
#include "../../interface/BlockStore.h"
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
//TODO Rename this to CachingBlockStore and the other one to something else
|
//TODO Rename this to CachingBlockStore and the other one to something else
|
||||||
//TODO Check that this blockstore allows parallel destructing of blocks (otherwise we won't encrypt blocks in parallel)
|
//TODO Check that this blockstore allows parallel destructing of blocks (otherwise we won't encrypt blocks in parallel)
|
||||||
class Caching2BlockStore: public BlockStore {
|
class CachingBlockStore: public BlockStore {
|
||||||
public:
|
public:
|
||||||
Caching2BlockStore(std::unique_ptr<BlockStore> baseBlockStore);
|
CachingBlockStore(std::unique_ptr<BlockStore> baseBlockStore);
|
||||||
|
|
||||||
std::unique_ptr<Block> create(size_t size) override;
|
std::unique_ptr<Block> create(size_t size) override;
|
||||||
std::unique_ptr<Block> load(const Key &key) override;
|
std::unique_ptr<Block> load(const Key &key) override;
|
||||||
@ -25,7 +25,7 @@ private:
|
|||||||
std::unique_ptr<BlockStore> _baseBlockStore;
|
std::unique_ptr<BlockStore> _baseBlockStore;
|
||||||
Cache _cache;
|
Cache _cache;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(Caching2BlockStore);
|
DISALLOW_COPY_AND_ASSIGN(CachingBlockStore);
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
@ -4,9 +4,10 @@
|
|||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
namespace blockstore {
|
namespace blockstore {
|
||||||
namespace caching2 {
|
namespace caching {
|
||||||
|
|
||||||
//TODO Test
|
//TODO Test
|
||||||
//TODO Move to utils
|
//TODO Move to utils
|
@ -1,23 +1,23 @@
|
|||||||
#include "../../../implementations/caching2/Caching2BlockStore.h"
|
#include "../../../implementations/caching/CachingBlockStore.h"
|
||||||
#include "../../../implementations/testfake/FakeBlockStore.h"
|
#include "../../../implementations/testfake/FakeBlockStore.h"
|
||||||
#include "../../testutils/BlockStoreTest.h"
|
#include "../../testutils/BlockStoreTest.h"
|
||||||
#include "google/gtest/gtest.h"
|
#include "google/gtest/gtest.h"
|
||||||
|
|
||||||
|
|
||||||
using blockstore::BlockStore;
|
using blockstore::BlockStore;
|
||||||
using blockstore::caching2::Caching2BlockStore;
|
using blockstore::caching::CachingBlockStore;
|
||||||
using blockstore::testfake::FakeBlockStore;
|
using blockstore::testfake::FakeBlockStore;
|
||||||
|
|
||||||
using std::unique_ptr;
|
using std::unique_ptr;
|
||||||
using std::make_unique;
|
using std::make_unique;
|
||||||
|
|
||||||
class Caching2BlockStoreTestFixture: public BlockStoreTestFixture {
|
class CachingBlockStoreTestFixture: public BlockStoreTestFixture {
|
||||||
public:
|
public:
|
||||||
unique_ptr<BlockStore> createBlockStore() override {
|
unique_ptr<BlockStore> createBlockStore() override {
|
||||||
return make_unique<Caching2BlockStore>(make_unique<FakeBlockStore>());
|
return make_unique<CachingBlockStore>(make_unique<FakeBlockStore>());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
INSTANTIATE_TYPED_TEST_CASE_P(Caching2, BlockStoreTest, Caching2BlockStoreTestFixture);
|
INSTANTIATE_TYPED_TEST_CASE_P(Caching, BlockStoreTest, CachingBlockStoreTestFixture);
|
||||||
|
|
||||||
//TODO Add specific tests for the blockstore
|
//TODO Add specific tests for the blockstore
|
@ -18,6 +18,6 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
INSTANTIATE_TYPED_TEST_CASE_P(Caching, BlockStoreTest, ParallelAccessBlockStoreTestFixture);
|
INSTANTIATE_TYPED_TEST_CASE_P(ParallelAccess, BlockStoreTest, ParallelAccessBlockStoreTestFixture);
|
||||||
|
|
||||||
//TODO Add specific tests ensuring that loading the same block twice doesn't load it twice from the underlying blockstore
|
//TODO Add specific tests ensuring that loading the same block twice doesn't load it twice from the underlying blockstore
|
||||||
|
Loading…
x
Reference in New Issue
Block a user