|
18 | 18 | package rest
|
19 | 19 |
|
20 | 20 | import (
|
| 21 | + "fmt" |
| 22 | + "net/http" |
| 23 | + "net/http/httptest" |
| 24 | + |
21 | 25 | "testing"
|
| 26 | + |
| 27 | + "github.com/bloodhoundad/azurehound/v2/client/config" |
22 | 28 | )
|
23 | 29 |
|
24 | 30 | func TestClosedConnection(t *testing.T) {
|
25 |
| - // var s *httptest.Server |
26 |
| - // var h http.HandlerFunc = func(w http.ResponseWriter, r *http.Request) { |
27 |
| - // fmt.Println("closing client connections") |
28 |
| - // s.CloseClientConnections() |
29 |
| - // } |
30 |
| - // s = httptest.NewServer(h) |
31 |
| - // defer s.Close() |
32 |
| - |
33 |
| - // res, err := RestClient.Get(gomock.Any(), s.URL) |
34 |
| - // if err == nil { |
35 |
| - // t.Fatalf("Something aint right, err should be nil %v", err) |
36 |
| - // } |
37 |
| - |
38 |
| - // fmt.Printf("res:%v,err:%v", res, err) |
| 31 | + attempt := 0 |
| 32 | + var testServer *httptest.Server |
| 33 | + var mockHandler http.HandlerFunc = func(w http.ResponseWriter, r *http.Request) { |
| 34 | + attempt++ |
| 35 | + testServer.CloseClientConnections() |
| 36 | + } |
| 37 | + |
| 38 | + testServer = httptest.NewServer(mockHandler) |
| 39 | + defer testServer.Close() |
| 40 | + |
| 41 | + defaultConfig := config.Config{ |
| 42 | + Username: "azurehound", |
| 43 | + Password: "we_collect", |
| 44 | + Authority: testServer.URL, |
| 45 | + } |
| 46 | + |
| 47 | + if client, err := NewRestClient(testServer.URL, defaultConfig); err != nil { |
| 48 | + t.Fatalf("error initializing rest client %v", err) |
| 49 | + } else { |
| 50 | + if req, err := http.NewRequest(http.MethodGet, testServer.URL, nil); err != nil { |
| 51 | + t.Fatalf("error creating request %v", err) |
| 52 | + } else { |
| 53 | + didSucceed := false |
| 54 | + |
| 55 | + // make request in separate goroutine so we can end it early after the first retry |
| 56 | + go func() { |
| 57 | + // end request on the second attempt after a closed connection |
| 58 | + if res, err := client.Send(req); err != nil { |
| 59 | + fmt.Println(err) |
| 60 | + } else if res.Status == "200" { |
| 61 | + didSucceed = true |
| 62 | + } |
| 63 | + }() |
| 64 | + |
| 65 | + for attempt < 3 { |
| 66 | + if attempt > 1 { |
| 67 | + return |
| 68 | + } |
| 69 | + } |
| 70 | + |
| 71 | + if didSucceed { |
| 72 | + t.Fatalf("expected an attempted retry but the request succeeded") |
| 73 | + } |
| 74 | + } |
| 75 | + } |
39 | 76 | }
|
0 commit comments