Skip to content

Commit

Permalink
fix: Skip commit for kustomize update if nothing changed
Browse files Browse the repository at this point in the history
Signed-off-by: Fs02 <[email protected]>
  • Loading branch information
Fs02 authored and chengfang committed Sep 20, 2024
1 parent 13f01ec commit 737f9fb
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 13 deletions.
35 changes: 23 additions & 12 deletions pkg/argocd/git.go
Original file line number Diff line number Diff line change
Expand Up @@ -329,40 +329,51 @@ func writeKustomization(app *v1alpha1.Application, wbc *WriteBackConfig, gitC gi
return err, false
}

if err = updateKustomizeFile(filterFunc, kustFile); err != nil {
return err, false
}

return nil, false
return updateKustomizeFile(filterFunc, kustFile)
}

// updateKustomizeFile reads the kustomization file at path, applies the filter to it, and writes the result back
// to the file. This is the same behavior as kyaml.UpdateFile, but it preserves the original order
// of YAML fields to minimize git diffs.
func updateKustomizeFile(filter kyaml.Filter, path string) error {
func updateKustomizeFile(filter kyaml.Filter, path string) (error, bool) {
// Read the yaml
y, err := kyaml.ReadFile(path)
if err != nil {
return err
return err, false
}

originalData, err := y.String()
if err != nil {
return err, false
}

// Update the yaml
yCpy := y.Copy()
if err := yCpy.PipeE(filter); err != nil {
return err
return err, false
}

// Preserve the original order of fields
if err := order.SyncOrder(y, yCpy); err != nil {
return err
return err, false
}

override, err := yCpy.String()
if err != nil {
return err, false
}

if originalData == override {
log.Debugf("target parameter file and marshaled data are the same, skipping commit.")
return nil, true
}

// Write the yaml
if err := kyaml.WriteFile(yCpy, path); err != nil {
return err
if err := os.WriteFile(path, []byte(override), 0600); err != nil {
return err, false
}

return nil
return nil, false
}

func imagesFilter(images v1alpha1.KustomizeImages) (kyaml.Filter, error) {
Expand Down
14 changes: 13 additions & 1 deletion pkg/argocd/git_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -270,13 +270,25 @@ func Test_updateKustomizeFile(t *testing.T) {
`,
filter: filter,
},
{
name: "no-change",
content: `images:
- name: foo
digest: sha23456
`,
wantContent: "",
filter: filter,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
path := makeTmpKustomization(t, []byte(tt.content))
err := updateKustomizeFile(tt.filter, path)
err, skip := updateKustomizeFile(tt.filter, path)
if tt.wantErr {
assert.Error(t, err)
} else if tt.name == "no-change" {
assert.Nil(t, err)
assert.True(t, skip)
} else {
got, err := os.ReadFile(path)
if err != nil {
Expand Down

0 comments on commit 737f9fb

Please sign in to comment.