mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-30 03:22:14 +00:00
Fixing tests.
This commit is contained in:
parent
4905201985
commit
3d6ace5890
@ -742,8 +742,11 @@ std::optional<UInt64> Connection::checkPacket(size_t timeout_microseconds)
|
||||
}
|
||||
|
||||
|
||||
Packet Connection::receivePacket()
|
||||
Packet Connection::receivePacket(Fiber * fiber)
|
||||
{
|
||||
in->setFiber(fiber);
|
||||
SCOPE_EXIT(in->setFiber(nullptr));
|
||||
|
||||
try
|
||||
{
|
||||
Packet res;
|
||||
|
@ -171,7 +171,7 @@ public:
|
||||
std::optional<UInt64> checkPacket(size_t timeout_microseconds = 0);
|
||||
|
||||
/// Receive packet from server.
|
||||
Packet receivePacket();
|
||||
Packet receivePacket(Fiber * fiber);
|
||||
|
||||
/// If not connected yet, or if connection is broken - then connect. If cannot connect - throw an exception.
|
||||
void forceConnected(const ConnectionTimeouts & timeouts);
|
||||
@ -190,7 +190,6 @@ public:
|
||||
size_t outBytesCount() const { return out ? out->count() : 0; }
|
||||
size_t inBytesCount() const { return in ? in->count() : 0; }
|
||||
|
||||
void setFiber(Fiber * fiber) { in->setFiber(fiber); }
|
||||
Poco::Net::Socket & getSocket() { return in->getSocket(); }
|
||||
|
||||
private:
|
||||
|
@ -237,7 +237,7 @@ std::string MultiplexedConnections::dumpAddressesUnlocked() const
|
||||
return buf.str();
|
||||
}
|
||||
|
||||
Packet MultiplexedConnections::receivePacketUnlocked()
|
||||
Packet MultiplexedConnections::receivePacketUnlocked(Fiber * fiber)
|
||||
{
|
||||
if (!sent_query)
|
||||
throw Exception("Cannot receive packets: no query sent.", ErrorCodes::LOGICAL_ERROR);
|
||||
@ -249,19 +249,7 @@ Packet MultiplexedConnections::receivePacketUnlocked()
|
||||
if (current_connection == nullptr)
|
||||
throw Exception("Logical error: no available replica", ErrorCodes::NO_AVAILABLE_REPLICA);
|
||||
|
||||
if (fiber)
|
||||
current_connection->setFiber(fiber);
|
||||
|
||||
Packet packet;
|
||||
{
|
||||
SCOPE_EXIT(
|
||||
{
|
||||
fiber = nullptr;
|
||||
current_connection->setFiber(fiber);
|
||||
});
|
||||
|
||||
packet = current_connection->receivePacket();
|
||||
}
|
||||
Packet packet = current_connection->receivePacket(fiber);
|
||||
|
||||
switch (packet.type)
|
||||
{
|
||||
|
@ -67,12 +67,11 @@ public:
|
||||
/// Without locking, because sendCancel() does not change the state of the replicas.
|
||||
bool hasActiveConnections() const { return active_connection_count > 0; }
|
||||
|
||||
void setFiber(Fiber * fiber_) { fiber = fiber_; }
|
||||
Poco::Net::Socket & getSocket() { return current_connection->getSocket(); }
|
||||
|
||||
private:
|
||||
/// Internal version of `receivePacket` function without locking.
|
||||
Packet receivePacketUnlocked();
|
||||
Packet receivePacketUnlocked(Fiber * fiber = nullptr);
|
||||
|
||||
/// Internal version of `dumpAddresses` function without locking.
|
||||
std::string dumpAddressesUnlocked() const;
|
||||
@ -109,8 +108,6 @@ private:
|
||||
/// in separate thread.
|
||||
mutable std::mutex cancel_mutex;
|
||||
|
||||
boost::context::fiber * fiber = nullptr;
|
||||
|
||||
friend class RemoteQueryExecutorReadContext;
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user