mirror of
				https://github.com/gin-gonic/gin.git
				synced 2025-10-23 01:57:55 +08:00 
			
		
		
		
	log request during panic when in debug mode
This commit is contained in:
		
							parent
							
								
									48c3482b5d
								
							
						
					
					
						commit
						21354b18b5
					
				| @ -11,6 +11,7 @@ import ( | |||||||
| 	"io/ioutil" | 	"io/ioutil" | ||||||
| 	"log" | 	"log" | ||||||
| 	"net/http" | 	"net/http" | ||||||
|  | 	"net/http/httputil" | ||||||
| 	"runtime" | 	"runtime" | ||||||
| 	"time" | 	"time" | ||||||
| ) | ) | ||||||
| @ -38,8 +39,13 @@ func RecoveryWithWriter(out io.Writer) HandlerFunc { | |||||||
| 			if err := recover(); err != nil { | 			if err := recover(); err != nil { | ||||||
| 				if logger != nil { | 				if logger != nil { | ||||||
| 					stack := stack(3) | 					stack := stack(3) | ||||||
|  | 					if IsDebugging() { | ||||||
|  | 						httprequest, _ := httputil.DumpRequest(c.Request, false) | ||||||
|  | 						logger.Printf("[Recovery] %s panic recovered:\n%s\n%s\n%s%s", timeFormat(time.Now()), string(httprequest), err, stack, reset) | ||||||
|  | 					} else { | ||||||
| 						logger.Printf("[Recovery] %s panic recovered:\n%s\n%s%s", timeFormat(time.Now()), err, stack, reset) | 						logger.Printf("[Recovery] %s panic recovered:\n%s\n%s%s", timeFormat(time.Now()), err, stack, reset) | ||||||
| 					} | 					} | ||||||
|  | 				} | ||||||
| 				c.AbortWithStatus(http.StatusInternalServerError) | 				c.AbortWithStatus(http.StatusInternalServerError) | ||||||
| 			} | 			} | ||||||
| 		}() | 		}() | ||||||
|  | |||||||
| @ -27,6 +27,15 @@ func TestPanicInHandler(t *testing.T) { | |||||||
| 	assert.Contains(t, buffer.String(), "panic recovered") | 	assert.Contains(t, buffer.String(), "panic recovered") | ||||||
| 	assert.Contains(t, buffer.String(), "Oupps, Houston, we have a problem") | 	assert.Contains(t, buffer.String(), "Oupps, Houston, we have a problem") | ||||||
| 	assert.Contains(t, buffer.String(), "TestPanicInHandler") | 	assert.Contains(t, buffer.String(), "TestPanicInHandler") | ||||||
|  | 
 | ||||||
|  | 	// Debug mode prints the request | ||||||
|  | 	SetMode(DebugMode) | ||||||
|  | 	// RUN | ||||||
|  | 	w = performRequest(router, "GET", "/recovery") | ||||||
|  | 	// TEST | ||||||
|  | 	assert.Equal(t, http.StatusInternalServerError, w.Code) | ||||||
|  | 	assert.Contains(t, buffer.String(), "GET /recovery") | ||||||
|  | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // TestPanicWithAbort assert that panic has been recovered even if context.Abort was used. | // TestPanicWithAbort assert that panic has been recovered even if context.Abort was used. | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user