From a8052889feb88a9ec659e8571f8a58d891edf678 Mon Sep 17 00:00:00 2001 From: Jesse Lucas Date: Thu, 18 Aug 2016 22:45:03 -0400 Subject: [PATCH] server-mux_test.go updating test to fix race condition with TestListenAndServe (#2485) --- cmd/server-mux_test.go | 43 ++++++++++++++++++++++++++++++++---------- 1 file changed, 33 insertions(+), 10 deletions(-) diff --git a/cmd/server-mux_test.go b/cmd/server-mux_test.go index 6d547b218..27798afb9 100644 --- a/cmd/server-mux_test.go +++ b/cmd/server-mux_test.go @@ -23,7 +23,9 @@ import ( "net" "net/http" "net/http/httptest" + "strconv" "testing" + "time" ) func TestClose(t *testing.T) { @@ -36,9 +38,7 @@ func TestClose(t *testing.T) { } func TestMuxServer(t *testing.T) { - ts := httptest.NewUnstartedServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { - fmt.Fprintln(w, "Hello, client") - })) + ts := httptest.NewUnstartedServer(nil) defer ts.Close() // Create ServerMux @@ -91,9 +91,7 @@ func TestMuxServer(t *testing.T) { } func TestServerCloseBlocking(t *testing.T) { - ts := httptest.NewUnstartedServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { - fmt.Fprintln(w, "Hello, client") - })) + ts := httptest.NewUnstartedServer(nil) defer ts.Close() // Create ServerMux @@ -146,17 +144,42 @@ func TestServerCloseBlocking(t *testing.T) { } func TestListenAndServe(t *testing.T) { - m := NewMuxServer("", nil) - stopc := make(chan struct{}) + wait := make(chan struct{}) + addr := "127.0.0.1:" + strconv.Itoa(getFreePort()) errc := make(chan error) + + // Create ServerMux and when we receive a request we stop waiting + m := NewMuxServer(addr, http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + fmt.Fprint(w, "hello") + close(wait) + })) + + // ListenAndServe in a goroutine, but we don't know when it's ready go func() { errc <- m.ListenAndServe() }() - go func() { errc <- m.Close(); close(stopc) }() + + // Make sure we don't block by closing wait after a timeout + tf := time.AfterFunc(time.Millisecond*100, func() { close(wait) }) + + // Keep trying the server until it's accepting connections + client := http.Client{Timeout: time.Millisecond * 10} + ok := false + for !ok { + res, _ := client.Get("http://" + addr) + if res != nil && res.StatusCode == http.StatusOK { + ok = true + } + } + + tf.Stop() // Cancel the timeout since we made a successful request + + // Block until we get an error or wait closed select { case err := <-errc: if err != nil { t.Fatal(err) } - case <-stopc: + case <-wait: + m.Close() // Shutdown the ServerMux return } }