diff --git a/dev-tools/packaging/package_test.go b/dev-tools/packaging/package_test.go index 249bd0bb6dbb..b094859d6602 100644 --- a/dev-tools/packaging/package_test.go +++ b/dev-tools/packaging/package_test.go @@ -36,6 +36,8 @@ import ( "strings" "testing" + "errors" + "github.com/blakesmith/ar" rpm "github.com/cavaliercoder/go-rpm" ) @@ -48,6 +50,7 @@ const ( ) var ( + excludedPathsPattern = regexp.MustCompile(`node_modules`) configFilePattern = regexp.MustCompile(`.*beat\.yml$|apm-server\.yml|elastic-agent\.yml$`) manifestFilePattern = regexp.MustCompile(`manifest.yml`) modulesDirPattern = regexp.MustCompile(`module/.+`) @@ -528,6 +531,9 @@ func readRPM(rpmFile string) (*packageFile, *rpm.PackageFile, error) { pf := &packageFile{Name: filepath.Base(rpmFile), Contents: map[string]packageEntry{}} for _, file := range contents { + if excludedPathsPattern.MatchString(file.Name()) { + continue + } pe := packageEntry{ File: file.Name(), Mode: file.Mode(), @@ -555,7 +561,7 @@ func readDeb(debFile string, dataBuffer *bytes.Buffer) (*packageFile, error) { for { header, err := arReader.Next() if err != nil { - if err == io.EOF { + if errors.Is(err, io.EOF) { break } return nil, err @@ -606,12 +612,16 @@ func readTarContents(tarName string, data io.Reader) (*packageFile, error) { for { header, err := tarReader.Next() if err != nil { - if err == io.EOF { + if errors.Is(err, io.EOF) { break } return nil, err } + if excludedPathsPattern.MatchString(header.Name) { + continue + } + p.Contents[header.Name] = packageEntry{ File: header.Name, UID: header.Uid, @@ -632,6 +642,9 @@ func readZip(zipFile string) (*packageFile, error) { p := &packageFile{Name: filepath.Base(zipFile), Contents: map[string]packageEntry{}} for _, f := range r.File { + if excludedPathsPattern.MatchString(f.Name) { + continue + } p.Contents[f.Name] = packageEntry{ File: f.Name, Mode: f.Mode(), @@ -662,7 +675,7 @@ func readDocker(dockerFile string) (*packageFile, *dockerInfo, error) { for { header, err := tarReader.Next() if err != nil { - if err == io.EOF { + if errors.Is(err, io.EOF) { break } return nil, nil, err @@ -708,6 +721,9 @@ func readDocker(dockerFile string) (*packageFile, *dockerInfo, error) { if strings.HasPrefix("/"+name, workingDir) || "/"+name == entrypoint { p.Contents[name] = entry } + if excludedPathsPattern.MatchString(name) { + continue + } // Add also licenses for _, licenseFile := range licenseFiles { if strings.Contains(name, licenseFile) {