mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-26 13:51:05 +01:00 
			
		
		
		
	presubmit: improve output (#3641)
* presubmit: buffer errors to display them all at once Signed-off-by: Sylvain Rabot <s.rabot@lectra.com> * presubmit: make path absolute so they can be clickable in shells Signed-off-by: Sylvain Rabot <s.rabot@lectra.com> * presubmit: remove useless return Signed-off-by: Sylvain Rabot <s.rabot@lectra.com> * presubmit: fix error message Signed-off-by: Sylvain Rabot <s.rabot@lectra.com> * presubmit: annotate Scanner error with concerned file path Signed-off-by: Sylvain Rabot <s.rabot@lectra.com>
This commit is contained in:
		
							parent
							
								
									995179a6c6
								
							
						
					
					
						commit
						510f2c503d
					
				| @ -16,13 +16,25 @@ import ( | |||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestTrailingWhitespace(t *testing.T) { | func TestTrailingWhitespace(t *testing.T) { | ||||||
| 	err := filepath.Walk("..", hasTrailingWhitespace) | 	walker := hasTrailingWhitespaceWalker{} | ||||||
|  | 	err := filepath.Walk("..", walker.walk) | ||||||
|  | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Fatal(err) | 		t.Fatal(err) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(walker.Errors) > 0 { | ||||||
|  | 		for _, err = range walker.Errors { | ||||||
|  | 			t.Error(err) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func hasTrailingWhitespace(path string, info os.FileInfo, _ error) error { | type hasTrailingWhitespaceWalker struct { | ||||||
|  | 	Errors []error | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (w *hasTrailingWhitespaceWalker) walk(path string, info os.FileInfo, _ error) error { | ||||||
| 	// Only handle regular files, skip files that are executable and skip file in the | 	// Only handle regular files, skip files that are executable and skip file in the | ||||||
| 	// root that start with a . | 	// root that start with a . | ||||||
| 	if !info.Mode().IsRegular() { | 	if !info.Mode().IsRegular() { | ||||||
| @ -42,25 +54,45 @@ func hasTrailingWhitespace(path string, info os.FileInfo, _ error) error { | |||||||
| 	defer file.Close() | 	defer file.Close() | ||||||
| 
 | 
 | ||||||
| 	scanner := bufio.NewScanner(file) | 	scanner := bufio.NewScanner(file) | ||||||
| 	for scanner.Scan() { | 	for i := 1; scanner.Scan(); i++ { | ||||||
| 		text := scanner.Text() | 		text := scanner.Text() | ||||||
| 		trimmed := strings.TrimRightFunc(text, unicode.IsSpace) | 		trimmed := strings.TrimRightFunc(text, unicode.IsSpace) | ||||||
| 		if len(text) != len(trimmed) { | 		if len(text) != len(trimmed) { | ||||||
| 			return fmt.Errorf("file %q has trailing whitespace, text: %q", path, text) | 			absPath, _ := filepath.Abs(path) | ||||||
|  | 			w.Errors = append(w.Errors, fmt.Errorf("file %q has trailing whitespace at line %d, text: %q", absPath, i, text)) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return scanner.Err() | 	err = scanner.Err() | ||||||
|  | 
 | ||||||
|  | 	if err != nil { | ||||||
|  | 		absPath, _ := filepath.Abs(path) | ||||||
|  | 		err = fmt.Errorf("file %q: %v", absPath, err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return err | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestFileNameHyphen(t *testing.T) { | func TestFileNameHyphen(t *testing.T) { | ||||||
| 	err := filepath.Walk("..", hasHyphen) | 	walker := hasHyphenWalker{} | ||||||
|  | 	err := filepath.Walk("..", walker.walk) | ||||||
|  | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Fatal(err) | 		t.Fatal(err) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(walker.Errors) > 0 { | ||||||
|  | 		for _, err = range walker.Errors { | ||||||
|  | 			t.Error(err) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func hasHyphen(path string, info os.FileInfo, _ error) error { | type hasHyphenWalker struct { | ||||||
|  | 	Errors []error | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (w *hasHyphenWalker) walk(path string, info os.FileInfo, _ error) error { | ||||||
| 	// only for regular files, not starting with a . and those that are go files. | 	// only for regular files, not starting with a . and those that are go files. | ||||||
| 	if !info.Mode().IsRegular() { | 	if !info.Mode().IsRegular() { | ||||||
| 		return nil | 		return nil | ||||||
| @ -73,7 +105,8 @@ func hasHyphen(path string, info os.FileInfo, _ error) error { | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if strings.Index(path, "-") > 0 { | 	if strings.Index(path, "-") > 0 { | ||||||
| 		return fmt.Errorf("file %q has a hyphen, please use underscores in file names", path) | 		absPath, _ := filepath.Abs(path) | ||||||
|  | 		w.Errors = append(w.Errors, fmt.Errorf("file %q has a hyphen, please use underscores in file names", absPath)) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return nil | 	return nil | ||||||
| @ -81,13 +114,25 @@ func hasHyphen(path string, info os.FileInfo, _ error) error { | |||||||
| 
 | 
 | ||||||
| // Test if error messages start with an upper case. | // Test if error messages start with an upper case. | ||||||
| func TestLowercaseLog(t *testing.T) { | func TestLowercaseLog(t *testing.T) { | ||||||
| 	err := filepath.Walk("..", hasLowercase) | 	walker := hasLowercaseWalker{} | ||||||
|  | 	err := filepath.Walk("..", walker.walk) | ||||||
|  | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Fatal(err) | 		t.Fatal(err) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(walker.Errors) > 0 { | ||||||
|  | 		for _, err = range walker.Errors { | ||||||
|  | 			t.Error(err) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func hasLowercase(path string, info os.FileInfo, _ error) error { | type hasLowercaseWalker struct { | ||||||
|  | 	Errors []error | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (w *hasLowercaseWalker) walk(path string, info os.FileInfo, _ error) error { | ||||||
| 	// only for regular files, not starting with a . and those that are go files. | 	// only for regular files, not starting with a . and those that are go files. | ||||||
| 	if !info.Mode().IsRegular() { | 	if !info.Mode().IsRegular() { | ||||||
| 		return nil | 		return nil | ||||||
| @ -107,7 +152,7 @@ func hasLowercase(path string, info os.FileInfo, _ error) error { | |||||||
| 	l := &logfmt{} | 	l := &logfmt{} | ||||||
| 	ast.Walk(l, f) | 	ast.Walk(l, f) | ||||||
| 	if l.err != nil { | 	if l.err != nil { | ||||||
| 		return l.err | 		w.Errors = append(w.Errors, l.err) | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| @ -176,13 +221,25 @@ func (l logfmt) Visit(n ast.Node) ast.Visitor { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestImportTesting(t *testing.T) { | func TestImportTesting(t *testing.T) { | ||||||
| 	err := filepath.Walk("..", hasImportTesting) | 	walker := hasLowercaseWalker{} | ||||||
|  | 	err := filepath.Walk("..", walker.walk) | ||||||
|  | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Fatal(err) | 		t.Fatal(err) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(walker.Errors) > 0 { | ||||||
|  | 		for _, err = range walker.Errors { | ||||||
|  | 			t.Error(err) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func hasImportTesting(path string, info os.FileInfo, _ error) error { | type hasImportTestingWalker struct { | ||||||
|  | 	Errors []error | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (w *hasImportTestingWalker) walk(path string, info os.FileInfo, _ error) error { | ||||||
| 	// only for regular files, not starting with a . and those that are go files. | 	// only for regular files, not starting with a . and those that are go files. | ||||||
| 	if !info.Mode().IsRegular() { | 	if !info.Mode().IsRegular() { | ||||||
| 		return nil | 		return nil | ||||||
| @ -202,7 +259,8 @@ func hasImportTesting(path string, info os.FileInfo, _ error) error { | |||||||
| 		} | 		} | ||||||
| 		for _, im := range f.Imports { | 		for _, im := range f.Imports { | ||||||
| 			if im.Path.Value == `"testing"` { | 			if im.Path.Value == `"testing"` { | ||||||
| 				return fmt.Errorf("file %q is importing %q", path, "testing") | 				absPath, _ := filepath.Abs(path) | ||||||
|  | 				w.Errors = append(w.Errors, fmt.Errorf("file %q is importing %q", absPath, "testing")) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @ -210,13 +268,25 @@ func hasImportTesting(path string, info os.FileInfo, _ error) error { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestImportOrdering(t *testing.T) { | func TestImportOrdering(t *testing.T) { | ||||||
| 	err := filepath.Walk("..", hasImportOrdering) | 	walker := testImportOrderingWalker{} | ||||||
|  | 	err := filepath.Walk("..", walker.walk) | ||||||
|  | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		t.Fatal(err) | 		t.Fatal(err) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(walker.Errors) > 0 { | ||||||
|  | 		for _, err = range walker.Errors { | ||||||
|  | 			t.Error(err) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func hasImportOrdering(path string, info os.FileInfo, _ error) error { | type testImportOrderingWalker struct { | ||||||
|  | 	Errors []error | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (w *testImportOrderingWalker) walk(path string, info os.FileInfo, _ error) error { | ||||||
| 	if !info.Mode().IsRegular() { | 	if !info.Mode().IsRegular() { | ||||||
| 		return nil | 		return nil | ||||||
| 	} | 	} | ||||||
| @ -252,7 +322,8 @@ func hasImportOrdering(path string, info os.FileInfo, _ error) error { | |||||||
| 			bl++ | 			bl++ | ||||||
| 		} | 		} | ||||||
| 		if bl > 2 { | 		if bl > 2 { | ||||||
| 			return fmt.Errorf("more than %d import blocks in %q", bl, path) | 			absPath, _ := filepath.Abs(path) | ||||||
|  | 			w.Errors = append(w.Errors, fmt.Errorf("more than %d import blocks in %q", bl, absPath)) | ||||||
| 		} | 		} | ||||||
| 		blocks[bl] = append(blocks[bl], im) | 		blocks[bl] = append(blocks[bl], im) | ||||||
| 		prevpos = line | 		prevpos = line | ||||||
| @ -272,7 +343,8 @@ func hasImportOrdering(path string, info os.FileInfo, _ error) error { | |||||||
| 		for _, p := range blocks[i] { | 		for _, p := range blocks[i] { | ||||||
| 			t := importtype(p.Path.Value) | 			t := importtype(p.Path.Value) | ||||||
| 			if t != ip[i] { | 			if t != ip[i] { | ||||||
| 				return fmt.Errorf("import path for %s is not of the same type %q in %q", p.Path.Value, ip[i], path) | 				absPath, _ := filepath.Abs(path) | ||||||
|  | 				w.Errors = append(w.Errors, fmt.Errorf("import path for %s is not of the same type %q in %q", p.Path.Value, ip[i], absPath)) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @ -291,12 +363,14 @@ func hasImportOrdering(path string, info os.FileInfo, _ error) error { | |||||||
| 		if ip[0] == "coredns" && ip[1] == "3rd" { | 		if ip[0] == "coredns" && ip[1] == "3rd" { | ||||||
| 			break // OK | 			break // OK | ||||||
| 		} | 		} | ||||||
| 		return fmt.Errorf("import path in %q are not in the right order (std -> coredns -> 3rd)", path) | 		absPath, _ := filepath.Abs(path) | ||||||
|  | 		w.Errors = append(w.Errors, fmt.Errorf("import path in %q are not in the right order (std -> coredns -> 3rd)", absPath)) | ||||||
| 	case 2: | 	case 2: | ||||||
| 		if ip[0] == "std" && ip[1] == "coredns" && ip[2] == "3rd" { | 		if ip[0] == "std" && ip[1] == "coredns" && ip[2] == "3rd" { | ||||||
| 			break // OK | 			break // OK | ||||||
| 		} | 		} | ||||||
| 		return fmt.Errorf("import path in %q are not in the right order (std -> coredns -> 3rd)", path) | 		absPath, _ := filepath.Abs(path) | ||||||
|  | 		w.Errors = append(w.Errors, fmt.Errorf("import path in %q are not in the right order (std -> coredns -> 3rd)", absPath)) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return nil | 	return nil | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user