package auth import ( "encoding/json" "net/http" "net/http/httptest" "testing" "ds2api/internal/config" ) func TestGetVercelConfigFallsBackToSavedConfig(t *testing.T) { t.Setenv("DS2API_CONFIG_JSON", `{"keys":["k1"],"vercel":{"token":"saved-token","project_id":"saved-project","team_id":"saved-team"}}`) t.Setenv("VERCEL_TOKEN", "") t.Setenv("VERCEL_PROJECT_ID", "") t.Setenv("VERCEL_TEAM_ID", "") h := &Handler{Store: config.LoadStore()} rec := httptest.NewRecorder() h.getVercelConfig(rec, httptest.NewRequest(http.MethodGet, "/admin/vercel/config", nil)) if rec.Code != http.StatusOK { t.Fatalf("expected 200, got %d: %s", rec.Code, rec.Body.String()) } var payload map[string]any if err := json.Unmarshal(rec.Body.Bytes(), &payload); err != nil { t.Fatalf("decode response: %v", err) } if payload["has_token"] != true { t.Fatalf("expected saved token to be detected: %#v", payload) } if payload["token_source"] != "config" || payload["project_id"] != "saved-project" || payload["team_id"] != "saved-team" { t.Fatalf("unexpected preconfig payload: %#v", payload) } if payload["token_preview"] == "saved-token" { t.Fatal("token preview leaked the full token") } }