mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-13 18:02:24 +00:00
Fix tests
This commit is contained in:
parent
710bba895e
commit
898139acae
@ -126,10 +126,6 @@ private:
|
|||||||
Poco::Logger * log;
|
Poco::Logger * log;
|
||||||
bool startup_restore_finished = false;
|
bool startup_restore_finished = false;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get list of file segments which intesect with `range`.
|
|
||||||
* If `key` is not in cache or there is not such range, return std::nullopt.
|
|
||||||
*/
|
|
||||||
FileSegments getImpl(
|
FileSegments getImpl(
|
||||||
const Key & key, const FileSegment::Range & range,
|
const Key & key, const FileSegment::Range & range,
|
||||||
[[maybe_unused]] std::lock_guard<std::mutex> & cache_lock);
|
[[maybe_unused]] std::lock_guard<std::mutex> & cache_lock);
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include <Common/FileCache.h>
|
#include <Common/FileCache.h>
|
||||||
#include <Common/CurrentThread.h>
|
#include <Common/CurrentThread.h>
|
||||||
#include <Common/filesystemHelpers.h>
|
#include <Common/filesystemHelpers.h>
|
||||||
|
#include <Common/tests/gtest_global_context.h>
|
||||||
#include <Common/SipHash.h>
|
#include <Common/SipHash.h>
|
||||||
#include <Common/hex.h>
|
#include <Common/hex.h>
|
||||||
#include <Interpreters/Context.h>
|
#include <Interpreters/Context.h>
|
||||||
@ -95,10 +96,7 @@ TEST(LRUFileCache, get)
|
|||||||
DB::ThreadStatus thread_status;
|
DB::ThreadStatus thread_status;
|
||||||
|
|
||||||
/// To work with cache need query_id and query context.
|
/// To work with cache need query_id and query context.
|
||||||
auto shared_context = DB::Context::createShared();
|
auto query_context = DB::Context::createCopy(getContext().context);
|
||||||
auto context = DB::Context::createGlobal(shared_context.get());
|
|
||||||
context->makeGlobalContext();
|
|
||||||
auto query_context = DB::Context::createCopy(context);
|
|
||||||
query_context->makeQueryContext();
|
query_context->makeQueryContext();
|
||||||
query_context->setCurrentQueryId("query_id");
|
query_context->setCurrentQueryId("query_id");
|
||||||
DB::CurrentThread::QueryScope query_scope_holder(query_context);
|
DB::CurrentThread::QueryScope query_scope_holder(query_context);
|
||||||
@ -343,7 +341,7 @@ TEST(LRUFileCache, get)
|
|||||||
std::thread other_1([&]
|
std::thread other_1([&]
|
||||||
{
|
{
|
||||||
DB::ThreadStatus thread_status_1;
|
DB::ThreadStatus thread_status_1;
|
||||||
auto query_context_1 = DB::Context::createCopy(context);
|
auto query_context_1 = DB::Context::createCopy(getContext().context);
|
||||||
query_context_1->makeQueryContext();
|
query_context_1->makeQueryContext();
|
||||||
query_context_1->setCurrentQueryId("query_id_1");
|
query_context_1->setCurrentQueryId("query_id_1");
|
||||||
DB::CurrentThread::QueryScope query_scope_holder_1(query_context_1);
|
DB::CurrentThread::QueryScope query_scope_holder_1(query_context_1);
|
||||||
@ -410,7 +408,7 @@ TEST(LRUFileCache, get)
|
|||||||
std::thread other_1([&]
|
std::thread other_1([&]
|
||||||
{
|
{
|
||||||
DB::ThreadStatus thread_status_1;
|
DB::ThreadStatus thread_status_1;
|
||||||
auto query_context_1 = DB::Context::createCopy(context);
|
auto query_context_1 = DB::Context::createCopy(getContext().context);
|
||||||
query_context_1->makeQueryContext();
|
query_context_1->makeQueryContext();
|
||||||
query_context_1->setCurrentQueryId("query_id_1");
|
query_context_1->setCurrentQueryId("query_id_1");
|
||||||
DB::CurrentThread::QueryScope query_scope_holder_1(query_context_1);
|
DB::CurrentThread::QueryScope query_scope_holder_1(query_context_1);
|
||||||
|
@ -34,6 +34,7 @@ CacheableReadBufferFromRemoteFS::CacheableReadBufferFromRemoteFS(
|
|||||||
, reader(reader_)
|
, reader(reader_)
|
||||||
, settings(settings_)
|
, settings(settings_)
|
||||||
, read_until_position(read_until_position_)
|
, read_until_position(read_until_position_)
|
||||||
|
, use_external_buffer(settings_.remote_fs_method == RemoteFSReadMethod::threadpool)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -227,9 +228,17 @@ bool CacheableReadBufferFromRemoteFS::nextImpl()
|
|||||||
|
|
||||||
assert(current_read_range.left <= file_offset_of_buffer_end);
|
assert(current_read_range.left <= file_offset_of_buffer_end);
|
||||||
assert(current_read_range.right >= file_offset_of_buffer_end);
|
assert(current_read_range.right >= file_offset_of_buffer_end);
|
||||||
assert(!internal_buffer.empty());
|
|
||||||
|
|
||||||
|
if (use_external_buffer)
|
||||||
|
{
|
||||||
|
assert(!internal_buffer.empty());
|
||||||
swap(*impl);
|
swap(*impl);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
impl->position() = position();
|
||||||
|
assert(!impl->hasPendingData());
|
||||||
|
}
|
||||||
|
|
||||||
bool result;
|
bool result;
|
||||||
auto & file_segment = *current_file_segment_it;
|
auto & file_segment = *current_file_segment_it;
|
||||||
@ -292,7 +301,10 @@ bool CacheableReadBufferFromRemoteFS::nextImpl()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (use_external_buffer)
|
||||||
swap(*impl);
|
swap(*impl);
|
||||||
|
else
|
||||||
|
BufferBase::set(impl->buffer().begin(), impl->buffer().size(), impl->offset());
|
||||||
|
|
||||||
if (file_offset_of_buffer_end > current_read_range.right)
|
if (file_offset_of_buffer_end > current_read_range.right)
|
||||||
completeFileSegmentAndGetNext();
|
completeFileSegmentAndGetNext();
|
||||||
|
@ -52,6 +52,9 @@ private:
|
|||||||
SeekableReadBufferPtr impl;
|
SeekableReadBufferPtr impl;
|
||||||
bool initialized = false;
|
bool initialized = false;
|
||||||
|
|
||||||
|
/// Flag to identify usage of threadpool reads
|
||||||
|
bool use_external_buffer;
|
||||||
|
|
||||||
enum class ReadType
|
enum class ReadType
|
||||||
{
|
{
|
||||||
CACHED,
|
CACHED,
|
||||||
|
@ -138,8 +138,6 @@ void ReadBufferFromRemoteFSGather::initialize()
|
|||||||
|
|
||||||
bool ReadBufferFromRemoteFSGather::nextImpl()
|
bool ReadBufferFromRemoteFSGather::nextImpl()
|
||||||
{
|
{
|
||||||
assert(!internal_buffer.empty());
|
|
||||||
|
|
||||||
/// Find first available buffer that fits to given offset.
|
/// Find first available buffer that fits to given offset.
|
||||||
if (!current_buf)
|
if (!current_buf)
|
||||||
initialize();
|
initialize();
|
||||||
|
@ -14,8 +14,7 @@ namespace ErrorCodes
|
|||||||
|
|
||||||
ReadIndirectBufferFromRemoteFS::ReadIndirectBufferFromRemoteFS(
|
ReadIndirectBufferFromRemoteFS::ReadIndirectBufferFromRemoteFS(
|
||||||
std::shared_ptr<ReadBufferFromRemoteFSGather> impl_)
|
std::shared_ptr<ReadBufferFromRemoteFSGather> impl_)
|
||||||
: ReadBufferFromFileBase(DBMS_DEFAULT_BUFFER_SIZE, nullptr, 0)
|
: impl(std::move(impl_))
|
||||||
, impl(std::move(impl_))
|
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,8 +73,6 @@ off_t ReadIndirectBufferFromRemoteFS::seek(off_t offset_, int whence)
|
|||||||
|
|
||||||
bool ReadIndirectBufferFromRemoteFS::nextImpl()
|
bool ReadIndirectBufferFromRemoteFS::nextImpl()
|
||||||
{
|
{
|
||||||
assert(!internal_buffer.empty());
|
|
||||||
|
|
||||||
/// Transfer current position and working_buffer to actual ReadBuffer
|
/// Transfer current position and working_buffer to actual ReadBuffer
|
||||||
swap(*impl);
|
swap(*impl);
|
||||||
/// Position and working_buffer will be updated in next() call
|
/// Position and working_buffer will be updated in next() call
|
||||||
|
Loading…
Reference in New Issue
Block a user