Tweaks some tests that were having a hard time in Travis CI and

bumps up the default retry time.
pull/3020/head
James Phillips 2017-05-08 21:57:06 -07:00
parent 66e1bb5c3e
commit 33a7b8e401
No known key found for this signature in database
GPG Key ID: 77183E682AC5FC11
5 changed files with 51 additions and 41 deletions

View File

@ -1306,10 +1306,15 @@ func TestDNS_ServiceLookup_WanAddress(t *testing.T) {
if got, want := len(srv1.agent.WANMembers()), 2; got < want { if got, want := len(srv1.agent.WANMembers()), 2; got < want {
r.Fatalf("got %d WAN members want at least %d", got, want) r.Fatalf("got %d WAN members want at least %d", got, want)
} }
if got, want := len(srv2.agent.WANMembers()), 2; got < want {
r.Fatalf("got %d WAN members want at least %d", got, want)
}
}) })
// Register a remote node with a service. // Register a remote node with a service. This is in a retry since we
{ // need the datacenter to have a route which takes a little more time
// beyond the join, and we don't have direct access to the router here.
retry.Run(t, func(r *retry.R) {
args := &structs.RegisterRequest{ args := &structs.RegisterRequest{
Datacenter: "dc2", Datacenter: "dc2",
Node: "foo", Node: "foo",
@ -1324,9 +1329,9 @@ func TestDNS_ServiceLookup_WanAddress(t *testing.T) {
var out struct{} var out struct{}
if err := srv2.agent.RPC("Catalog.Register", args, &out); err != nil { if err := srv2.agent.RPC("Catalog.Register", args, &out); err != nil {
t.Fatalf("err: %v", err) r.Fatalf("err: %v", err)
} }
} })
// Register an equivalent prepared query. // Register an equivalent prepared query.
var id string var id string
@ -3381,10 +3386,15 @@ func TestDNS_PreparedQuery_Failover(t *testing.T) {
if got, want := len(srv1.agent.WANMembers()), 2; got < want { if got, want := len(srv1.agent.WANMembers()), 2; got < want {
r.Fatalf("got %d WAN members want at least %d", got, want) r.Fatalf("got %d WAN members want at least %d", got, want)
} }
if got, want := len(srv2.agent.WANMembers()), 2; got < want {
r.Fatalf("got %d WAN members want at least %d", got, want)
}
}) })
// Register a remote node with a service. // Register a remote node with a service. This is in a retry since we
{ // need the datacenter to have a route which takes a little more time
// beyond the join, and we don't have direct access to the router here.
retry.Run(t, func(r *retry.R) {
args := &structs.RegisterRequest{ args := &structs.RegisterRequest{
Datacenter: "dc2", Datacenter: "dc2",
Node: "foo", Node: "foo",
@ -3399,9 +3409,9 @@ func TestDNS_PreparedQuery_Failover(t *testing.T) {
var out struct{} var out struct{}
if err := srv2.agent.RPC("Catalog.Register", args, &out); err != nil { if err := srv2.agent.RPC("Catalog.Register", args, &out); err != nil {
t.Fatalf("err: %v", err) r.Fatalf("err: %v", err)
} }
} })
// Register a local prepared query. // Register a local prepared query.
{ {

View File

@ -434,29 +434,29 @@ func TestLeader_LeftServer(t *testing.T) {
dir3, s3 := testServerDCBootstrap(t, "dc1", false) dir3, s3 := testServerDCBootstrap(t, "dc1", false)
defer os.RemoveAll(dir3) defer os.RemoveAll(dir3)
defer s3.Shutdown() defer s3.Shutdown()
servers := []*Server{s1, s2, s3}
// Put s1 last so we don't trigger a leader election.
servers := []*Server{s2, s3, s1}
// Try to join // Try to join
joinLAN(t, s2, s1) joinLAN(t, s2, s1)
joinLAN(t, s3, s1) joinLAN(t, s3, s1)
for _, s := range servers { for _, s := range servers {
retry.Run(t, func(r *retry.R) { r.Check(wantPeers(s, 3)) }) retry.Run(t, func(r *retry.R) { r.Check(wantPeers(s, 3)) })
} }
retry.Run(t, func(r *retry.R) { // Kill any server
// Kill any server servers[0].Shutdown()
servers[0].Shutdown()
// Force remove the non-leader (transition to left state) // Force remove the non-leader (transition to left state)
if err := servers[1].RemoveFailedNode(servers[0].config.NodeName); err != nil { if err := servers[1].RemoveFailedNode(servers[0].config.NodeName); err != nil {
r.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
for _, s := range servers[1:] { // Wait until the remaining servers show only 2 peers.
retry.Run(t, func(r *retry.R) { r.Check(wantPeers(s, 2)) }) for _, s := range servers[1:] {
} retry.Run(t, func(r *retry.R) { r.Check(wantPeers(s, 2)) })
}) }
} }
func TestLeader_LeftLeader(t *testing.T) { func TestLeader_LeftLeader(t *testing.T) {

View File

@ -184,12 +184,12 @@ func TestServer_JoinWAN(t *testing.T) {
}) })
// Check the router has both // Check the router has both
if len(s1.router.GetDatacenters()) != 2 {
t.Fatalf("remote consul missing")
}
retry.Run(t, func(r *retry.R) { retry.Run(t, func(r *retry.R) {
if got, want := len(s1.router.GetDatacenters()), 2; got != want {
r.Fatalf("got %d routes want %d", got, want)
}
if got, want := len(s2.router.GetDatacenters()), 2; got != want { if got, want := len(s2.router.GetDatacenters()), 2; got != want {
r.Fatalf("got %d data centers want %d", got, want) r.Fatalf("got %d datacenters want %d", got, want)
} }
}) })
} }
@ -273,17 +273,17 @@ func TestServer_JoinSeparateLanAndWanAddresses(t *testing.T) {
}) })
// Check the router has both // Check the router has both
if len(s1.router.GetDatacenters()) != 2 { retry.Run(t, func(r *retry.R) {
t.Fatalf("remote consul missing") if len(s1.router.GetDatacenters()) != 2 {
} r.Fatalf("remote consul missing")
}
if len(s2.router.GetDatacenters()) != 2 { if len(s2.router.GetDatacenters()) != 2 {
t.Fatalf("remote consul missing") r.Fatalf("remote consul missing")
} }
if len(s2.localConsuls) != 2 {
if len(s2.localConsuls) != 2 { r.Fatalf("local consul fellow s3 for s2 missing")
t.Fatalf("local consul fellow s3 for s2 missing") }
} })
// Get and check the wan address of s2 from s1 // Get and check the wan address of s2 from s1
var s2WanAddr string var s2WanAddr string

View File

@ -82,7 +82,7 @@ func decorate(s string) string {
} }
func Run(t Failer, f func(r *R)) { func Run(t Failer, f func(r *R)) {
run(OneSec(), t, f) run(TwoSeconds(), t, f)
} }
func RunWith(r Retryer, t Failer, f func(r *R)) { func RunWith(r Retryer, t Failer, f func(r *R)) {
@ -133,9 +133,9 @@ func run(r Retryer, t Failer, f func(r *R)) {
} }
} }
// OneSec repeats an operation for one second and waits 25ms in between. // TwoSeconds repeats an operation for two seconds and waits 25ms in between.
func OneSec() *Timer { func TwoSeconds() *Timer {
return &Timer{Timeout: time.Second, Wait: 25 * time.Millisecond} return &Timer{Timeout: 2 * time.Second, Wait: 25 * time.Millisecond}
} }
// ThreeTimes repeats an operation three times and waits 25ms in between. // ThreeTimes repeats an operation three times and waits 25ms in between.

View File

@ -6,7 +6,7 @@ import (
) )
// delta defines the time band a test run should complete in. // delta defines the time band a test run should complete in.
var delta = 5 * time.Millisecond var delta = 10 * time.Millisecond
func TestRetryer(t *testing.T) { func TestRetryer(t *testing.T) {
tests := []struct { tests := []struct {