homebox/backend/pkgs/server/server_test.go

100 lines
1.8 KiB
Go
Raw Normal View History

2022-08-30 02:30:36 +00:00
package server
import (
"net/http"
"sync/atomic"
2022-08-30 02:30:36 +00:00
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func testServer(t *testing.T, r http.Handler) *Server {
svr := NewServer(WithHost("127.0.0.1"), WithPort("19245"))
2022-08-30 02:30:36 +00:00
go func() {
2022-09-03 09:52:05 +00:00
err := svr.Start(r)
assert.NoError(t, err)
2022-08-30 02:30:36 +00:00
}()
ping := func() error {
_, err := http.Get("http://127.0.0.1:19245")
return err
}
for {
if err := ping(); err == nil {
break
}
time.Sleep(time.Millisecond * 100)
}
return svr
}
func Test_ServerShutdown_Error(t *testing.T) {
svr := NewServer(WithHost("127.0.0.1"), WithPort("19245"))
2022-08-30 02:30:36 +00:00
err := svr.Shutdown("test")
assert.ErrorIs(t, err, ErrServerNotStarted)
}
func Test_ServerStarts_Error(t *testing.T) {
svr := testServer(t, nil)
err := svr.Start(nil)
assert.ErrorIs(t, err, ErrServerAlreadyStarted)
err = svr.Shutdown("test")
assert.NoError(t, err)
}
func Test_ServerStarts(t *testing.T) {
svr := testServer(t, nil)
err := svr.Shutdown("test")
assert.NoError(t, err)
}
func Test_GracefulServerShutdownWithWorkers(t *testing.T) {
isFinished := false
svr := testServer(t, nil)
svr.Background(func() {
time.Sleep(time.Second * 4)
isFinished = true
})
err := svr.Shutdown("test")
assert.NoError(t, err)
assert.True(t, isFinished)
}
func Test_GracefulServerShutdownWithRequests(t *testing.T) {
var isFinished atomic.Bool
2022-08-30 02:30:36 +00:00
router := http.NewServeMux()
// add long running handler func
router.HandleFunc("/test", func(rw http.ResponseWriter, r *http.Request) {
time.Sleep(time.Second * 3)
isFinished.Store(true)
2022-08-30 02:30:36 +00:00
})
svr := testServer(t, router)
// Make request to "/test"
go func() {
2022-09-03 09:52:05 +00:00
_, _ = http.Get("http://127.0.0.1:19245/test") // This is probably bad?
2022-08-30 02:30:36 +00:00
}()
time.Sleep(time.Second) // Hack to wait for the request to be made
err := svr.Shutdown("test")
assert.NoError(t, err)
assert.True(t, isFinished.Load())
2022-08-30 02:30:36 +00:00
}