show SharedState in Debug for Runtime

This should be useful to debug deadlocks due to bad forking.
This commit is contained in:
Aleksey Kladov 2018-12-21 12:12:06 +03:00
parent 31789ec7ef
commit 52206d5421

View file

@ -56,7 +56,8 @@ where
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
fmt.debug_struct("Runtime") fmt.debug_struct("Runtime")
.field("id", &self.id()) .field("id", &self.id())
.field("revision", &self.current_revision()) .field("forked", &self.revision_guard.is_some())
.field("shared_state", &self.shared_state)
.finish() .finish()
} }
} }
@ -398,6 +399,26 @@ impl<DB: Database> Default for SharedState<DB> {
} }
} }
impl<DB> std::fmt::Debug for SharedState<DB>
where
DB: Database,
{
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
let query_lock = if self.query_lock.try_write().is_some() {
"<unlocked>"
} else if self.query_lock.try_read().is_some() {
"<rlocked>"
} else {
"<wlocked>"
};
fmt.debug_struct("SharedState")
.field("query_lock", &query_lock)
.field("revision", &self.revision)
.field("pending_revision_increments", &self.pending_revision_increments)
.finish()
}
}
/// State that will be specific to a single execution threads (when we /// State that will be specific to a single execution threads (when we
/// support multiple threads) /// support multiple threads)
struct LocalState<DB: Database> { struct LocalState<DB: Database> {