diff --git a/pkg/update/update.go b/pkg/update/update.go index 459c54687..0303b75c8 100644 --- a/pkg/update/update.go +++ b/pkg/update/update.go @@ -369,7 +369,7 @@ func (o *Options) updateGitPackage(ctx context.Context, repo *git.Repository, pa root := worktree.Filesystem.Root() log.Printf("working directory: %s", root) - configFile := filepath.Join(root, pc.Filename) + configFile := filepath.Join(pc.Dir, pc.Filename) if configFile == "" { return "", fmt.Errorf("no config filename found for package %s", packageName) } @@ -416,7 +416,7 @@ func (o *Options) updateGitPackage(ctx context.Context, repo *git.Repository, pa } // now make sure update config is configured - updated, err := config.ParseConfiguration(ctx, filepath.Join(root, pc.Filename)) + updated, err := config.ParseConfiguration(ctx, filepath.Join(pc.Dir, pc.Filename)) if err != nil { return "", fmt.Errorf("failed to parse %v", err) } @@ -435,7 +435,7 @@ func (o *Options) updateGitPackage(ctx context.Context, repo *git.Repository, pa // Skip any processing for definitions with a single pipeline if len(updated.Pipeline) > 1 && deps.ContainsGoBumpPipeline(updated) { - if err := o.updateGoBumpDeps(updated, root, pc.Filename, mutations); err != nil { + if err := o.updateGoBumpDeps(updated, pc.Dir, pc.Filename, mutations); err != nil { return fmt.Sprintf("error cleaning up go/bump deps: %v", err), nil } } @@ -447,12 +447,16 @@ func (o *Options) updateGitPackage(ctx context.Context, repo *git.Repository, pa o.Logger.Printf("after clean go bumps: %s git status: %s", packageName, string(rs)) // Run yam formatter - err = yam.FormatConfigurationFile(root, pc.Filename) + err = yam.FormatConfigurationFile(root, filepath.Join(pc.Dir, pc.Filename)) if err != nil { return fmt.Sprintf("failed to format configuration file: %v", err), nil } - _, err = worktree.Add(pc.Filename) + relativeFilename, err := filepath.Rel(pc.Dir, pc.Filename) + if err != nil { + return "", fmt.Errorf("failed to get relative path from dir %s and file %s: %v", pc.Dir, pc.Filename, err) + } + _, err = worktree.Add(relativeFilename) if err != nil { return "", fmt.Errorf("failed to git add %s: %w", configFile, err) } diff --git a/pkg/yam/yam.go b/pkg/yam/yam.go index fa3d7d39f..3ed51538b 100644 --- a/pkg/yam/yam.go +++ b/pkg/yam/yam.go @@ -22,9 +22,15 @@ func FormatConfigurationFile(dir, filename string) error { return fmt.Errorf("failed to read yam config file: %v", err) } + // remove root dir from filename + relativeFilename, err := filepath.Rel(dir, filename) + if err != nil { + return fmt.Errorf("failed to get relative path from dir %s and file %s: %v", dir, filename, err) + } + fsys := osAdapter.DirFS(dir) // Format file following the repo level format - err = yam.Format(fsys, []string{filename}, yam.FormatOptions{EncodeOptions: *encodeOptions}) + err = yam.Format(fsys, []string{relativeFilename}, yam.FormatOptions{EncodeOptions: *encodeOptions}) if err != nil { return fmt.Errorf("error formatting the file %s: %v", filename, err) }