summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon MacMullen <simon@rabbitmq.com>2011-02-07 11:42:35 +0000
committerSimon MacMullen <simon@rabbitmq.com>2011-02-07 11:42:35 +0000
commite57589d51a18a7128ce2c26a4313b2ad4bac7e32 (patch)
tree04d189cd94826cbb65a6d8c7e5f97d3086b7d5e5
parent709ed272ed055c1a6473f577cfffe772d040c55a (diff)
parentee08297297f7a1976dc8efbeccdb6e15370c4c5d (diff)
downloadrabbitmq-server-e57589d51a18a7128ce2c26a4313b2ad4bac7e32.tar.gz
Merge bug 23061 into default (spurious heartbeat timeouts possible during connection termination)
-rw-r--r--src/rabbit_reader.erl6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/rabbit_reader.erl b/src/rabbit_reader.erl
index b5d82ac2..76d392f9 100644
--- a/src/rabbit_reader.erl
+++ b/src/rabbit_reader.erl
@@ -357,7 +357,11 @@ mainloop(Deb, State = #v1{parent = Parent, sock= Sock, recv_ref = Ref}) ->
throw({handshake_timeout, State#v1.callback})
end;
timeout ->
- throw({timeout, State#v1.connection_state});
+ ConnectionState = State#v1.connection_state,
+ case ConnectionState of
+ closed -> mainloop(Deb, State);
+ _ -> throw({timeout, ConnectionState})
+ end;
{'$gen_call', From, {shutdown, Explanation}} ->
{ForceTermination, NewState} = terminate(Explanation, State),
gen_server:reply(From, ok),