type serverCmd struct {
// Can be used to stop the server. Useful in tests
stop <-chan bool
- // Can be used to receive notification about when the server is started. Useful in tests.
- started chan<- bool
disableLiveReload bool
navigateToChanged bool
}
func newServerCmd() *serverCmd {
- return newServerCmdSignaled(nil, nil)
+ return newServerCmdSignaled(nil)
}
-func newServerCmdSignaled(stop <-chan bool, started chan<- bool) *serverCmd {
- cc := &serverCmd{stop: stop, started: started}
+func newServerCmdSignaled(stop <-chan bool) *serverCmd {
+ cc := &serverCmd{stop: stop}
cc.baseBuilderCmd = newBuilderCmd(&cobra.Command{
Use: "server",
}()
}
- if s.started != nil {
- s.started <- true
- }
-
jww.FEEDBACK.Println("Press Ctrl+C to stop")
if s.stop != nil {
os.RemoveAll(dir)
}()
- stop, started := make(chan bool), make(chan bool)
+ stop := make(chan bool)
- scmd := newServerCmdSignaled(stop, started)
+ scmd := newServerCmdSignaled(stop)
cmd := scmd.getCommand()
cmd.SetArgs([]string{"-s=" + dir, fmt.Sprintf("-p=%d", port)})
assert.NoError(err)
}()
- select {
- case <-started:
- case <-time.After(2 * time.Second):
- t.Fatal("server start took too long")
- }
+ // There is no way to know exactly when the server is ready for connections.
+ // We could improve by something like https://golang.org/pkg/net/http/httptest/#Server
+ // But for now, let us sleep and pray!
+ time.Sleep(2 * time.Second)
resp, err := http.Get("http://localhost:1331/")
assert.NoError(err)