Skip to content

Commit

Permalink
Refactor AppendError to check for build.NoGoError
Browse files Browse the repository at this point in the history
  • Loading branch information
alexandear committed Dec 18, 2024
1 parent e21b4d4 commit a89b7b7
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 2 deletions.
4 changes: 3 additions & 1 deletion analyzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
package gosec

import (
"errors"
"fmt"
"go/ast"
"go/build"
Expand Down Expand Up @@ -543,7 +544,8 @@ func (gosec *Analyzer) ParseErrors(pkg *packages.Package) error {
// AppendError appends an error to the file errors
func (gosec *Analyzer) AppendError(file string, err error) {
// Do not report the error for empty packages (e.g. files excluded from build with a tag)
if strings.Contains(err.Error(), "no buildable Go source files in") {
var noGoErr *build.NoGoError
if errors.As(err, &noGoErr) {
return
}
errors := make([]Error, 0)
Expand Down
6 changes: 5 additions & 1 deletion analyzer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ package gosec_test

import (
"errors"
"go/build"
"log"
"regexp"
"strings"
Expand Down Expand Up @@ -1311,7 +1312,10 @@ var _ = Describe("Analyzer", func() {

Context("when appending errors", func() {
It("should skip error for non-buildable packages", func() {
analyzer.AppendError("test", errors.New(`loading file from package "pkg/test": no buildable Go source files in pkg/test`))
err := &build.NoGoError{
Dir: "pkg/test",
}
analyzer.AppendError("test", err)
_, _, errors := analyzer.Report()
Expect(errors).To(BeEmpty())
})
Expand Down

0 comments on commit a89b7b7

Please sign in to comment.