2023-06-01 06:43:35 -07:00
|
|
|
package elect_test
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"testing"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
2023-06-04 10:43:32 -07:00
|
|
|
func TestOne(t *testing.T) {
|
2023-06-01 06:43:35 -07:00
|
|
|
t.Parallel()
|
|
|
|
|
|
2023-06-04 10:43:32 -07:00
|
|
|
ts := NewTestSystem(t, 1)
|
2023-06-04 10:31:26 -07:00
|
|
|
defer ts.Stop()
|
2023-06-01 06:43:35 -07:00
|
|
|
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(0).IsLeader())
|
|
|
|
|
|
2023-06-04 13:59:06 -07:00
|
|
|
require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond)
|
2023-06-01 06:43:35 -07:00
|
|
|
}
|
2023-06-04 13:44:26 -07:00
|
|
|
|
|
|
|
|
func TestThree(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
|
|
ts := NewTestSystem(t, 3)
|
|
|
|
|
defer ts.Stop()
|
|
|
|
|
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(0).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(1).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(2).IsLeader())
|
|
|
|
|
|
2023-06-04 13:59:06 -07:00
|
|
|
require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond)
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(1).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(2).IsLeader())
|
2023-06-04 13:44:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestFailover(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
|
|
ts := NewTestSystem(t, 3)
|
|
|
|
|
defer ts.Stop()
|
|
|
|
|
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(0).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(1).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(2).IsLeader())
|
|
|
|
|
|
2023-06-04 13:59:06 -07:00
|
|
|
require.Eventually(t, ts.Candidate(0).IsLeader, 20*time.Second, 100*time.Millisecond)
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(1).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(2).IsLeader())
|
2023-06-04 13:44:26 -07:00
|
|
|
|
|
|
|
|
ts.SetServer(1)
|
|
|
|
|
|
|
|
|
|
require.Eventually(t, func() bool { return !ts.Candidate(0).IsLeader() }, 15*time.Second, 100*time.Millisecond)
|
|
|
|
|
|
2023-06-04 13:59:06 -07:00
|
|
|
// New candidate must not get leadership before old candidate loses it
|
|
|
|
|
require.False(t, ts.Candidate(1).IsLeader())
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(2).IsLeader())
|
2023-06-04 13:44:26 -07:00
|
|
|
|
2023-06-04 13:59:06 -07:00
|
|
|
require.Eventually(t, ts.Candidate(1).IsLeader, 20*time.Second, 100*time.Millisecond)
|
2023-06-04 14:04:15 -07:00
|
|
|
require.False(t, ts.Candidate(0).IsLeader())
|
|
|
|
|
require.False(t, ts.Candidate(2).IsLeader())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestPartialVotes(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
|
|
ts := NewTestSystem(t, 3)
|
|
|
|
|
defer ts.Stop()
|
|
|
|
|
|
|
|
|
|
ts.Voter(0).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())
|
2023-06-04 13:44:26 -07:00
|
|
|
}
|