Skip to content
This repository has been archived by the owner on Mar 11, 2023. It is now read-only.

Commit

Permalink
Support per-Dockerfile dockerignore files
Browse files Browse the repository at this point in the history
Since Docker 19.03, Docker looks for ${dockerfile_name}.dockerignore
files first, before falling back to .dockerignore if it doesn't exist.
  • Loading branch information
alex-hunt-materialize committed Feb 5, 2022
1 parent 4783008 commit 3ce16b8
Showing 1 changed file with 15 additions and 6 deletions.
21 changes: 15 additions & 6 deletions cmd/pulumi-resource-docker-buildkit/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -382,17 +382,26 @@ func (ch *contextHash) hexSum() string {
}

func hashContext(contextPath string, dockerfile string) (string, error) {
dockerIgnore, err := os.ReadFile(filepath.Join(contextPath, ".dockerignore"))
if err != nil && !os.IsNotExist(err) {
return "", fmt.Errorf("unable to read .dockerignore file: %w", err)
dockerIgnorePath := dockerfile + ".dockerignore"
dockerIgnore, err := os.ReadFile(dockerIgnorePath)
if err != nil {
if os.IsNotExist(err) {
dockerIgnorePath = filepath.Join(contextPath, ".dockerignore")
dockerIgnore, err = os.ReadFile(dockerIgnorePath)
if err != nil && !os.IsNotExist(err) {
return "", fmt.Errorf("unable to read %s file: %w", dockerIgnorePath, err)
}
} else {
return "", fmt.Errorf("unable to read %s file: %w", dockerIgnorePath, err)
}
}
ignorePatterns, err := dockerignore.ReadAll(bytes.NewReader(dockerIgnore))
if err != nil {
return "", fmt.Errorf("unable to parse .dockerignore file: %w", err)
return "", fmt.Errorf("unable to parse %s file: %w", dockerIgnorePath, err)
}
ignoreMatcher, err := fileutils.NewPatternMatcher(ignorePatterns)
if err != nil {
return "", fmt.Errorf("unable to load rules from .dockerignore: %w", err)
return "", fmt.Errorf("unable to load rules from %s: %w", dockerIgnorePath, err)
}
ch := newContextHash(contextPath)
err = ch.hashPath(dockerfile, 0)
Expand All @@ -412,7 +421,7 @@ func hashContext(contextPath string, dockerfile string) (string, error) {
}
ignore, err := ignoreMatcher.Matches(path)
if err != nil {
return fmt.Errorf(".dockerignore rule failed: %w", err)
return fmt.Errorf("%s rule failed: %w", dockerIgnorePath, err)
}
if ignore {
if d.IsDir() {
Expand Down

0 comments on commit 3ce16b8

Please sign in to comment.