Go でのライブ リクエストによる HTTP サーバーのテスト
ハンドラーの単体テストは不可欠ですが、ルーティングやその他のミドルウェアの影響が見落とされる可能性があります。包括的なテストの場合は、「ライブ サーバー」アプローチの使用を検討してください。
httptest.Server を使用したライブ サーバー テスト
net/http/httptest.Server タイプによりライブが容易になります。サーバーのテスト。提供されたハンドラー (この場合は、Gorilla mux ルーター) を使用してサーバーを作成します。次に例を示します。
<code class="go">func TestIndex(t *testing.T) { // Create server using the router initialized elsewhere. ts := httptest.NewServer(router) defer ts.Close() 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 }{ // Test GET and POST requests. {name: "1: testing get", r: newreq("GET", ts.URL+"/", nil)}, {name: "2: testing post", r: newreq("POST", ts.URL+"/", nil)}, // reader argument 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) } // check for expected response here. }) } }</code>
httptest.Server は、Gorilla mux だけでなく、http.Handler インターフェイスを満たす任意のハンドラーをテストするために使用できることに注意してください。
考慮事項
ライブサーバーテストはより現実的なテストを提供しますが、単体テストよりも時間がかかり、リソースを大量に消費する可能性があります。包括的なテスト戦略として、単体テストと統合テストの組み合わせを検討してください。
以上がGo でライブ リクエストを使用して HTTP サーバーをテストする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。