// Copyright 2024 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package server_test import ( "context" "fmt" "io" "net/http" "os" "strings" "testing" "github.com/googleapis/genai-toolbox/internal/log" "github.com/googleapis/genai-toolbox/internal/server" "github.com/googleapis/genai-toolbox/internal/telemetry" ) func TestServe(t *testing.T) { ctx, cancel := context.WithCancel(context.Background()) defer cancel() addr, port := "127.0.0.1", 5000 cfg := server.ServerConfig{ Version: "0.0.0", Address: addr, Port: port, } otelShutdown, err := telemetry.SetupOTel(ctx, "0.0.0", "", false, "toolbox") if err != nil { t.Fatalf("unexpected error: %s", err) } defer func() { err := otelShutdown(ctx) if err != nil { t.Fatalf("unexpected error: %s", err) } }() testLogger, err := log.NewStdLogger(os.Stdout, os.Stderr, "info") if err != nil { t.Fatalf("unexpected error: %s", err) } s, err := server.NewServer(context.Background(), cfg, testLogger) if err != nil { t.Fatalf("unable to initialize server: %v", err) } err = s.Listen(ctx) if err != nil { t.Fatalf("unable to start server: %v", err) } // start server in background errCh := make(chan error) go func() { defer close(errCh) err = s.Serve() if err != nil { errCh <- err } }() url := fmt.Sprintf("http://%s:%d/", addr, port) resp, err := http.Get(url) if err != nil { t.Fatalf("error when sending a request: %s", err) } defer resp.Body.Close() if resp.StatusCode != 200 { t.Fatalf("response status code is not 200") } raw, err := io.ReadAll(resp.Body) if err != nil { t.Fatalf("error reading from request body: %s", err) } if got := string(raw); strings.Contains(got, "0.0.0") { t.Fatalf("version missing from output: %q", got) } }