2021-02-01 07:37:56 +01:00
|
|
|
package controller
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math/rand"
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2022-12-06 07:41:09 +01:00
|
|
|
"github.com/TwiN/gatus/v5/config"
|
|
|
|
"github.com/TwiN/gatus/v5/config/web"
|
|
|
|
"github.com/TwiN/gatus/v5/core"
|
2023-07-09 02:37:41 +02:00
|
|
|
"github.com/gofiber/fiber/v2"
|
2021-02-01 07:37:56 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestHandle(t *testing.T) {
|
|
|
|
cfg := &config.Config{
|
2021-09-22 06:47:51 +02:00
|
|
|
Web: &web.Config{
|
2021-02-01 07:37:56 +01:00
|
|
|
Address: "0.0.0.0",
|
|
|
|
Port: rand.Intn(65534),
|
|
|
|
},
|
2021-10-23 22:47:12 +02:00
|
|
|
Endpoints: []*core.Endpoint{
|
2021-02-01 07:37:56 +01:00
|
|
|
{
|
|
|
|
Name: "frontend",
|
|
|
|
Group: "core",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "backend",
|
|
|
|
Group: "core",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
_ = os.Setenv("ROUTER_TEST", "true")
|
|
|
|
_ = os.Setenv("ENVIRONMENT", "dev")
|
2021-02-06 02:45:28 +01:00
|
|
|
defer os.Clearenv()
|
2022-07-29 02:07:53 +02:00
|
|
|
Handle(cfg)
|
2021-02-25 04:41:36 +01:00
|
|
|
defer Shutdown()
|
2023-07-09 02:37:41 +02:00
|
|
|
request := httptest.NewRequest("GET", "/health", http.NoBody)
|
|
|
|
response, err := app.Test(request)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if response.StatusCode != 200 {
|
2021-02-01 07:37:56 +01:00
|
|
|
t.Error("expected GET /health to return status code 200")
|
|
|
|
}
|
2023-07-09 02:37:41 +02:00
|
|
|
if app == nil {
|
2021-02-01 07:37:56 +01:00
|
|
|
t.Fatal("server should've been set (but because we set ROUTER_TEST, it shouldn't have been started)")
|
|
|
|
}
|
|
|
|
}
|
2021-02-06 02:45:28 +01:00
|
|
|
|
2023-04-22 21:22:09 +02:00
|
|
|
func TestHandleTLS(t *testing.T) {
|
|
|
|
scenarios := []struct {
|
|
|
|
name string
|
|
|
|
tls *web.TLSConfig
|
|
|
|
expectedStatusCode int
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "good-tls-config",
|
|
|
|
tls: &web.TLSConfig{CertificateFile: "../testdata/cert.pem", PrivateKeyFile: "../testdata/cert.key"},
|
|
|
|
expectedStatusCode: 200,
|
2023-04-22 18:12:56 +02:00
|
|
|
},
|
|
|
|
}
|
2023-04-22 21:22:09 +02:00
|
|
|
for _, scenario := range scenarios {
|
|
|
|
t.Run(scenario.name, func(t *testing.T) {
|
|
|
|
cfg := &config.Config{
|
|
|
|
Web: &web.Config{Address: "0.0.0.0", Port: rand.Intn(65534), TLS: scenario.tls},
|
|
|
|
Endpoints: []*core.Endpoint{
|
|
|
|
{Name: "frontend", Group: "core"},
|
|
|
|
{Name: "backend", Group: "core"},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
if err := cfg.Web.ValidateAndSetDefaults(); err != nil {
|
|
|
|
t.Error("expected no error from web (TLS) validation, got", err)
|
|
|
|
}
|
|
|
|
_ = os.Setenv("ROUTER_TEST", "true")
|
|
|
|
_ = os.Setenv("ENVIRONMENT", "dev")
|
|
|
|
defer os.Clearenv()
|
|
|
|
Handle(cfg)
|
|
|
|
defer Shutdown()
|
2023-07-09 02:37:41 +02:00
|
|
|
request := httptest.NewRequest("GET", "/health", http.NoBody)
|
|
|
|
response, err := app.Test(request)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if response.StatusCode != scenario.expectedStatusCode {
|
|
|
|
t.Errorf("%s %s should have returned %d, but returned %d instead", request.Method, request.URL, scenario.expectedStatusCode, response.StatusCode)
|
2023-04-22 21:22:09 +02:00
|
|
|
}
|
2023-07-09 02:37:41 +02:00
|
|
|
if app == nil {
|
2023-04-22 21:22:09 +02:00
|
|
|
t.Fatal("server should've been set (but because we set ROUTER_TEST, it shouldn't have been started)")
|
|
|
|
}
|
|
|
|
})
|
2023-04-22 18:12:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-06 02:45:28 +01:00
|
|
|
func TestShutdown(t *testing.T) {
|
|
|
|
// Pretend that we called controller.Handle(), which initializes the server variable
|
2023-07-09 02:37:41 +02:00
|
|
|
app = fiber.New()
|
2021-02-06 02:45:28 +01:00
|
|
|
Shutdown()
|
2023-07-09 02:37:41 +02:00
|
|
|
if app != nil {
|
2021-02-06 02:45:28 +01:00
|
|
|
t.Error("server should've been shut down")
|
|
|
|
}
|
|
|
|
}
|