| 
									
										
										
										
											2017-06-13 15:47:17 -07:00
										 |  |  | package debug | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/coredns/coredns/core/dnsserver" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-03 09:04:47 +08:00
										 |  |  | 	"github.com/caddyserver/caddy" | 
					
						
							| 
									
										
										
										
											2017-06-13 15:47:17 -07:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestDebug(t *testing.T) { | 
					
						
							|  |  |  | 	tests := []struct { | 
					
						
							|  |  |  | 		input         string | 
					
						
							|  |  |  | 		shouldErr     bool | 
					
						
							|  |  |  | 		expectedDebug bool | 
					
						
							|  |  |  | 	}{ | 
					
						
							|  |  |  | 		// positive | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			`debug`, false, true, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		// negative | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			`debug off`, true, false, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i, test := range tests { | 
					
						
							|  |  |  | 		c := caddy.NewTestController("dns", test.input) | 
					
						
							|  |  |  | 		err := setup(c) | 
					
						
							|  |  |  | 		cfg := dnsserver.GetConfig(c) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if test.shouldErr && err == nil { | 
					
						
							|  |  |  | 			t.Fatalf("Test %d: Expected error but found %s for input %s", i, err, test.input) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			if !test.shouldErr { | 
					
						
							|  |  |  | 				t.Fatalf("Test %d: Expected no error but found one for input %s. Error was: %v", i, test.input, err) | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if cfg.Debug != test.expectedDebug { | 
					
						
							| 
									
										
										
										
											2017-06-14 09:37:10 -07:00
										 |  |  | 			t.Fatalf("Test %d: Expected debug to be: %t, but got: %t, input: %s", i, test.expectedDebug, cfg.Debug, test.input) | 
					
						
							| 
									
										
										
										
											2017-06-13 15:47:17 -07:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |