package handler import ( "net/http" "net/http/httptest" "testing" "time" "github.com/TwiN/gatus/v3/config" "github.com/TwiN/gatus/v3/core" "github.com/TwiN/gatus/v3/storage" "github.com/TwiN/gatus/v3/watchdog" ) func TestResponseTimeChart(t *testing.T) { defer storage.Get().Clear() defer cache.Clear() cfg := &config.Config{ Metrics: true, Services: []*core.Service{ { Name: "frontend", Group: "core", }, { Name: "backend", Group: "core", }, }, } watchdog.UpdateServiceStatuses(cfg.Services[0], &core.Result{Success: true, Duration: time.Millisecond, Timestamp: time.Now()}) watchdog.UpdateServiceStatuses(cfg.Services[1], &core.Result{Success: false, Duration: time.Second, Timestamp: time.Now()}) router := CreateRouter("../../web/static", cfg.Security, nil, cfg.Metrics) type Scenario struct { Name string Path string ExpectedCode int Gzip bool } scenarios := []Scenario{ { Name: "chart-response-time-24h", Path: "/api/v1/services/core_backend/response-times/24h/chart.svg", ExpectedCode: http.StatusOK, }, { Name: "chart-response-time-7d", Path: "/api/v1/services/core_frontend/response-times/7d/chart.svg", ExpectedCode: http.StatusOK, }, { Name: "chart-response-time-with-invalid-duration", Path: "/api/v1/services/core_backend/response-times/3d/chart.svg", ExpectedCode: http.StatusBadRequest, }, { Name: "chart-response-time-for-invalid-key", Path: "/api/v1/services/invalid_key/response-times/7d/chart.svg", ExpectedCode: http.StatusNotFound, }, } for _, scenario := range scenarios { t.Run(scenario.Name, func(t *testing.T) { request, _ := http.NewRequest("GET", scenario.Path, nil) if scenario.Gzip { request.Header.Set("Accept-Encoding", "gzip") } responseRecorder := httptest.NewRecorder() router.ServeHTTP(responseRecorder, request) if responseRecorder.Code != scenario.ExpectedCode { t.Errorf("%s %s should have returned %d, but returned %d instead", request.Method, request.URL, scenario.ExpectedCode, responseRecorder.Code) } }) } }