Go での HTTP サーバーのライブ テスト
HTTP ハンドラーを単体テストするときは、HTTP ハンドラーがさまざまなリクエスト メソッドに正確に応答することを確認することが重要です。単体テストは、Gorilla mux などのルーターで使用される場合、サーバーの実際の動作を反映しないことがよくあります。包括的なテストには、「ライブ サーバー」バージョンが必要です。
解決策: httptest.Server の使用
net/http/httptest.Server タイプは便利な方法を提供します。テスト用のライブサーバーを作成します。入力としてハンドラーを受け取ります。ハンドラーは、ルーター、ServeMux、またはハンドラー インターフェイスを実装する任意のタイプにすることができます。次のコードはその使用法を示しています:
<code class="go">import ( "io" "net/http" "net/http/httptest" "testing" ) func TestIndex(t *testing.T) { // Initialize the router as you would in a production environment. router := mux.NewRouter() router.HandleFunc("/", views.Index).Methods("GET") // Create a live server using the router. ts := httptest.NewServer(router) defer ts.Close() // Define a function to create requests for different methods and URLs. newreq := func(method, url string, body io.Reader) *http.Request { r, err := http.NewRequest(method, url, body) if err != nil { t.Fatal(err) } return r } tests := []struct { name string r *http.Request }{ {name: "1: testing get", r: newreq("GET", ts.URL+"/", nil)}, {name: "2: testing post", r: newreq("POST", ts.URL+"/", nil)}, // body required for POST } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { resp, err := http.DefaultClient.Do(tt.r) defer resp.Body.Close() if err != nil { t.Fatal(err) } // Perform any additional checks on the response. }) } }</code>
このアプローチにより、ルーターおよびハンドラー関数を含むリクエスト処理パイプライン全体をテストできます。これにより、ハンドラーがさまざまな HTTP メソッドに正しく応答し、ライブ サーバー環境で期待どおりの結果が生成されることが保証されます。
以上がGo で HTTP サーバーのライブ テストを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。