| 
									
										
										
										
											2016-10-02 15:58:01 +01:00
										 |  |  | package file | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 22:51:47 -08:00
										 |  |  | 	"github.com/coredns/coredns/middleware/test" | 
					
						
							| 
									
										
										
										
											2016-10-02 15:58:01 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/mholt/caddy" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestFileParse(t *testing.T) { | 
					
						
							|  |  |  | 	zoneFileName1, rm, err := test.TempFile(".", dbMiekNL) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	defer rm() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	zoneFileName2, rm, err := test.TempFile(".", dbDnssexNLSigned) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	defer rm() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tests := []struct { | 
					
						
							|  |  |  | 		inputFileRules string | 
					
						
							|  |  |  | 		shouldErr      bool | 
					
						
							|  |  |  | 		expectedZones  Zones | 
					
						
							|  |  |  | 	}{ | 
					
						
							| 
									
										
										
										
											2016-10-02 19:41:00 +01:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			`file ` + zoneFileName1 + ` miek.nl { | 
					
						
							|  |  |  | 				transfer from 127.0.0.1 | 
					
						
							|  |  |  | 			}`, | 
					
						
							|  |  |  | 			true, | 
					
						
							|  |  |  | 			Zones{}, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2016-10-02 15:58:01 +01:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			`file`, | 
					
						
							|  |  |  | 			true, | 
					
						
							|  |  |  | 			Zones{}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			`file ` + zoneFileName1 + ` miek.nl.`, | 
					
						
							|  |  |  | 			false, | 
					
						
							|  |  |  | 			Zones{Names: []string{"miek.nl."}}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			`file ` + zoneFileName2 + ` dnssex.nl.`, | 
					
						
							|  |  |  | 			false, | 
					
						
							|  |  |  | 			Zones{Names: []string{"dnssex.nl."}}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i, test := range tests { | 
					
						
							| 
									
										
										
										
											2016-10-11 20:42:28 +01:00
										 |  |  | 		c := caddy.NewTestController("dns", test.inputFileRules) | 
					
						
							| 
									
										
										
										
											2016-10-02 15:58:01 +01:00
										 |  |  | 		actualZones, err := fileParse(c) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if err == nil && test.shouldErr { | 
					
						
							|  |  |  | 			t.Fatalf("Test %d expected errors, but got no error", i) | 
					
						
							|  |  |  | 		} else if err != nil && !test.shouldErr { | 
					
						
							|  |  |  | 			t.Fatalf("Test %d expected no errors, but got '%v'", i, err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			if len(actualZones.Names) != len(test.expectedZones.Names) { | 
					
						
							|  |  |  | 				t.Fatalf("Test %d expected %v, got %v", i, test.expectedZones.Names, actualZones.Names) | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			for j, name := range test.expectedZones.Names { | 
					
						
							|  |  |  | 				if actualZones.Names[j] != name { | 
					
						
							|  |  |  | 					t.Fatalf("Test %d expected %v for %d th zone, got %v", i, name, j, actualZones.Names[j]) | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |