mirror of
				https://github.com/gin-gonic/gin.git
				synced 2025-10-23 01:57:55 +08:00 
			
		
		
		
	improve panic information when a catch-all wildcard conflict occurs (#1529)
This commit is contained in:
		
							parent
							
								
									500ad23339
								
							
						
					
					
						commit
						d02ae1eb1a
					
				
							
								
								
									
										11
									
								
								tree.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								tree.go
									
									
									
									
									
								
							| @ -193,9 +193,16 @@ func (n *node) addRoute(path string, handlers HandlersChain) { | |||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
| 
 | 
 | ||||||
| 					panic("path segment '" + path + | 					pathSeg := path | ||||||
|  | 					if n.nType != catchAll { | ||||||
|  | 						pathSeg = strings.SplitN(path, "/", 2)[0] | ||||||
|  | 					} | ||||||
|  | 					prefix := fullPath[:strings.Index(fullPath, pathSeg)] + n.path | ||||||
|  | 					panic("'" + pathSeg + | ||||||
|  | 						"' in new path '" + fullPath + | ||||||
| 						"' conflicts with existing wildcard '" + n.path + | 						"' conflicts with existing wildcard '" + n.path + | ||||||
| 						"' in path '" + fullPath + "'") | 						"' in existing prefix '" + prefix + | ||||||
|  | 						"'") | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 				c := path[0] | 				c := path[0] | ||||||
|  | |||||||
							
								
								
									
										42
									
								
								tree_test.go
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								tree_test.go
									
									
									
									
									
								
							| @ -5,7 +5,9 @@ | |||||||
| package gin | package gin | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"fmt" | ||||||
| 	"reflect" | 	"reflect" | ||||||
|  | 	"regexp" | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"testing" | 	"testing" | ||||||
| ) | ) | ||||||
| @ -653,3 +655,43 @@ func TestTreeInvalidNodeType(t *testing.T) { | |||||||
| 		t.Fatalf("Expected panic '"+panicMsg+"', got '%v'", recv) | 		t.Fatalf("Expected panic '"+panicMsg+"', got '%v'", recv) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func TestTreeWildcardConflictEx(t *testing.T) { | ||||||
|  | 	conflicts := [...]struct { | ||||||
|  | 		route        string | ||||||
|  | 		segPath      string | ||||||
|  | 		existPath    string | ||||||
|  | 		existSegPath string | ||||||
|  | 	}{ | ||||||
|  | 		{"/who/are/foo", "/foo", `/who/are/\*you`, `/\*you`}, | ||||||
|  | 		{"/who/are/foo/", "/foo/", `/who/are/\*you`, `/\*you`}, | ||||||
|  | 		{"/who/are/foo/bar", "/foo/bar", `/who/are/\*you`, `/\*you`}, | ||||||
|  | 		{"/conxxx", "xxx", `/con:tact`, `:tact`}, | ||||||
|  | 		{"/conooo/xxx", "ooo", `/con:tact`, `:tact`}, | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	for _, conflict := range conflicts { | ||||||
|  | 		// I have to re-create a 'tree', because the 'tree' will be | ||||||
|  | 		// in an inconsistent state when the loop recovers from the | ||||||
|  | 		// panic which threw by 'addRoute' function. | ||||||
|  | 		tree := &node{} | ||||||
|  | 		routes := [...]string{ | ||||||
|  | 			"/con:tact", | ||||||
|  | 			"/who/are/*you", | ||||||
|  | 			"/who/foo/hello", | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		for _, route := range routes { | ||||||
|  | 			tree.addRoute(route, fakeHandler(route)) | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		recv := catchPanic(func() { | ||||||
|  | 			tree.addRoute(conflict.route, fakeHandler(conflict.route)) | ||||||
|  | 		}) | ||||||
|  | 
 | ||||||
|  | 		if !regexp.MustCompile(fmt.Sprintf("'%s' in new path .* conflicts with existing wildcard '%s' in existing prefix '%s'", | ||||||
|  | 			conflict.segPath, conflict.existSegPath, conflict.existPath)).MatchString(fmt.Sprint(recv)) { | ||||||
|  | 			t.Fatalf("invalid wildcard conflict error (%v)", recv) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user