Return instrumented response writer from context
This is ensures that users of the ResponseWriter from the context correctly track usage. Otherwise, context reporting is incorrect. Signed-off-by: Stephen J Day <stephen.day@docker.com>
This commit is contained in:
		
							parent
							
								
									dd0effe29a
								
							
						
					
					
						commit
						c06c6ba3bf
					
				
					 2 changed files with 12 additions and 3 deletions
				
			
		|  | @ -302,7 +302,7 @@ func (irw *instrumentedResponseWriter) Flush() { | |||
| func (irw *instrumentedResponseWriter) Value(key interface{}) interface{} { | ||||
| 	if keyStr, ok := key.(string); ok { | ||||
| 		if keyStr == "http.response" { | ||||
| 			return irw.ResponseWriter | ||||
| 			return irw | ||||
| 		} | ||||
| 
 | ||||
| 		if !strings.HasPrefix(keyStr, "http.response.") { | ||||
|  |  | |||
|  | @ -132,8 +132,17 @@ func TestWithResponseWriter(t *testing.T) { | |||
| 	trw := testResponseWriter{} | ||||
| 	ctx, rw := WithResponseWriter(Background(), &trw) | ||||
| 
 | ||||
| 	if ctx.Value("http.response") != &trw { | ||||
| 		t.Fatalf("response not available in context: %v != %v", ctx.Value("http.response"), &trw) | ||||
| 	if ctx.Value("http.response") != rw { | ||||
| 		t.Fatalf("response not available in context: %v != %v", ctx.Value("http.response"), rw) | ||||
| 	} | ||||
| 
 | ||||
| 	grw, err := GetResponseWriter(ctx) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("error getting response writer: %v", err) | ||||
| 	} | ||||
| 
 | ||||
| 	if grw != rw { | ||||
| 		t.Fatalf("unexpected response writer returned: %#v != %#v", grw, rw) | ||||
| 	} | ||||
| 
 | ||||
| 	if n, err := rw.Write(make([]byte, 1024)); err != nil { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue