Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Keep yaml sequence indentation when writing back to Git to a kustomize file #1002

Merged

Conversation

AlessandroZanatta
Copy link
Contributor

@AlessandroZanatta AlessandroZanatta commented Jan 9, 2025

Hi,

I've created a PR that should solve #501. First time I (really) contribute to an open-source project, so feel free to criticize anything I may have done wrong!

I have based this PR on the v0.15.2 branch instead of master as master was failing for me (throwing panics at runtime in my cluster). Let me know whether this is fine.

I've basically changed the way the updateKustomizeFile function in pkg/argocd/git.go works. It now uses kio.ByteReadWriter, which allows to preserve sequence indentation.
I also had to slightly modify how the comparison is done: kio adds some metadata.annotations to the yaml document, hence my approach was to get the output from the writer (which clears those annotations), and then parse it again with kyaml, hence ensuring that indentation is the same across the two files.

I'm also planning of sending a PR to kyaml to add a boolean that optionally retains the initial triple dashes of a document, if present (though I have yet to dig on kyaml code). To me, that would be a very nice achievement, as git diffs would become truly the smallest they can be!

I hope that my explanation (and code) make sense!

EDIT: added a test case for the change

@AlessandroZanatta
Copy link
Contributor Author

AlessandroZanatta commented Jan 9, 2025

I can already see that I screwed up, as all the commits from v0.15.2 are listed above.

Also, should I add a Signed-off-by: ... to my commit message to make the DCO action pass?

EDIT: branched from master and added Signed-off-by: ...

@codecov-commenter
Copy link

codecov-commenter commented Jan 9, 2025

Codecov Report

Attention: Patch coverage is 53.84615% with 18 lines in your changes missing coverage. Please review.

Project coverage is 63.26%. Comparing base (941e369) to head (2ef55eb).
Report is 5 commits behind head on master.

Files with missing lines Patch % Lines
pkg/argocd/git.go 53.84% 10 Missing and 8 partials ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master    #1002      +/-   ##
==========================================
- Coverage   63.42%   63.26%   -0.17%     
==========================================
  Files          15       15              
  Lines        2212     2243      +31     
==========================================
+ Hits         1403     1419      +16     
- Misses        723      733      +10     
- Partials       86       91       +5     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

AlessandroZanatta added a commit to AlessandroZanatta/homelab that referenced this pull request Jan 9, 2025
@AlessandroZanatta
Copy link
Contributor Author

Sorry about the spam with the commit on my repo. I was hoping for GitHub not to mention a commit PR link on an unrelated repository in the actual PR... seems I was wrong!

@chengfang
Copy link
Collaborator

Thanks for implementing this enhancement. Will take a closer look.

pkg/argocd/git_test.go Show resolved Hide resolved
if len(yCpySlice) != 1 {
return errors.New("target parameter file should contain a single YAML document"), false
}
yCpy := yCpySlice[0]
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

in the beginning of the func, we called kyaml.ReadFile to get the originl RNode and originalData. Then here we call os.Open to get the input stream to kio ReadWriter. I think we could remove the first read, and use the 2nd read to get the original RNode and originalData before any modification. WDTY?

Copy link
Contributor Author

@AlessandroZanatta AlessandroZanatta Jan 10, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Makes sense. It might be a bit verbose, as we cannot simply use the kio.ByteReadWriter due to it adding its own metadata.annotations. I agree though that we should avoid having two reads back to back, I'll try to work out a readable solution!

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@chengfang Just a heads up in case my commit got lost amidst other stuff. I've updated the code, feel free to review it when you've got the time to do so, thanks!

Changed variable names to clarify usage.

Signed-off-by: Alessandro Zanatta <[email protected]>
PreserveSeqIndent: true,
}

// Read input file
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

shall we change it to "// Read from input buffer" instead of file?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Updated!

return err, false
}

// yCpy contains metadata used by kio to preserve sequence indentation,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

did you mean newY instead of yCpy in the above comment?
Just 2 optional nit comments. Overall looks good.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I missed that, thanks. Updated!

@chengfang chengfang merged commit 154f51a into argoproj-labs:master Jan 14, 2025
10 of 11 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants