pub enum ElectionOutcome {
Elected {
term: u64,
votes: usize,
needed: usize,
},
ProbeFailed {
votes: usize,
needed: usize,
},
Lost {
term: u64,
votes: usize,
needed: usize,
},
NotElectable,
TimedOut {
votes: usize,
needed: usize,
},
}Expand description
The result of an election attempt.
Variants§
Elected
Won a majority and was promoted under term. votes/needed record
the tally (including the candidate’s self-vote).
ProbeFailed
The dry-run probe did not reach a majority, so no term was bumped and no real election was attempted (requirement 1).
Lost
A real election was attempted (term bumped) but did not reach a majority — e.g. votes split or peers came online between probe and election. The term has advanced; a later attempt stands for a higher term.
NotElectable
The candidate is not electable (a witness, or a catching-up replica, or its own log does not cover the watermark). No probe was sent.
TimedOut
The election ran past its randomized timeout before collecting a majority. No promotion happened.
Implementations§
Source§impl ElectionOutcome
impl ElectionOutcome
pub fn is_elected(&self) -> bool
Trait Implementations§
Source§impl Clone for ElectionOutcome
impl Clone for ElectionOutcome
Source§fn clone(&self) -> ElectionOutcome
fn clone(&self) -> ElectionOutcome
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for ElectionOutcome
impl Debug for ElectionOutcome
impl Eq for ElectionOutcome
Source§impl PartialEq for ElectionOutcome
impl PartialEq for ElectionOutcome
Source§fn eq(&self, other: &ElectionOutcome) -> bool
fn eq(&self, other: &ElectionOutcome) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for ElectionOutcome
Auto Trait Implementations§
impl Freeze for ElectionOutcome
impl RefUnwindSafe for ElectionOutcome
impl Send for ElectionOutcome
impl Sync for ElectionOutcome
impl Unpin for ElectionOutcome
impl UnsafeUnpin for ElectionOutcome
impl UnwindSafe for ElectionOutcome
Blanket Implementations§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request