More robust testing, TestSplitVotes
This commit is contained in:
@@ -10,7 +10,7 @@ import (
|
||||
func TestOne(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
ts := NewTestSystem(t, 1)
|
||||
ts := NewTestSystem(t, 1, 1)
|
||||
defer ts.Stop()
|
||||
|
||||
require.False(t, ts.Candidate(0).IsLeader())
|
||||
@@ -21,49 +21,66 @@ func TestOne(t *testing.T) {
|
||||
func TestThree(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
ts := NewTestSystem(t, 3)
|
||||
ts := NewTestSystem(t, 3, 3)
|
||||
defer ts.Stop()
|
||||
|
||||
require.False(t, ts.Candidate(0).IsLeader())
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
|
||||
require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond)
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
{
|
||||
w := NewWaiter()
|
||||
|
||||
w.Async(func() { require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(2).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
|
||||
w.Wait()
|
||||
}
|
||||
}
|
||||
|
||||
func TestFailover(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
ts := NewTestSystem(t, 3)
|
||||
ts := NewTestSystem(t, 3, 3)
|
||||
defer ts.Stop()
|
||||
|
||||
require.False(t, ts.Candidate(0).IsLeader())
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
|
||||
require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond)
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
{
|
||||
w := NewWaiter()
|
||||
|
||||
w.Async(func() { require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(2).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
|
||||
w.Wait()
|
||||
}
|
||||
|
||||
ts.SetServer(1)
|
||||
|
||||
require.Eventually(t, func() bool { return !ts.Candidate(0).IsLeader() }, 15*time.Second, 100*time.Millisecond)
|
||||
|
||||
// New candidate must not get leadership before old candidate loses it
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
|
||||
require.Eventually(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond)
|
||||
require.False(t, ts.Candidate(0).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
{
|
||||
w := NewWaiter()
|
||||
|
||||
w.Async(func() { require.Eventually(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(2).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
|
||||
w.Wait()
|
||||
}
|
||||
}
|
||||
|
||||
func TestPartialVotes(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
ts := NewTestSystem(t, 3)
|
||||
ts := NewTestSystem(t, 3, 3)
|
||||
defer ts.Stop()
|
||||
|
||||
ts.Proxy(0).SetRefuse(true)
|
||||
@@ -72,7 +89,37 @@ func TestPartialVotes(t *testing.T) {
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
|
||||
require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond)
|
||||
{
|
||||
w := NewWaiter()
|
||||
|
||||
w.Async(func() { require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(2).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
|
||||
w.Wait()
|
||||
}
|
||||
}
|
||||
|
||||
func TestSplitVotes(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
ts := NewTestSystem(t, 3, 3)
|
||||
defer ts.Stop()
|
||||
|
||||
ts.SetServerForVoter(1, 1)
|
||||
ts.SetServerForVoter(1, 2)
|
||||
|
||||
require.False(t, ts.Candidate(0).IsLeader())
|
||||
require.False(t, ts.Candidate(1).IsLeader())
|
||||
require.False(t, ts.Candidate(2).IsLeader())
|
||||
|
||||
{
|
||||
w := NewWaiter()
|
||||
|
||||
w.Async(func() { require.Eventually(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
w.Async(func() { require.Never(t, ts.Candidate(2).IsLeader, 20*time.Second, 100*time.Millisecond) })
|
||||
|
||||
w.Wait()
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user