-
Notifications
You must be signed in to change notification settings - Fork 272
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
Keep yaml sequence indentation when writing back to Git to a kustomize file #1002
Conversation
I can already see that I screwed up, as all the commits from v0.15.2 are listed above. Also, should I add a EDIT: branched from master and added |
…back to Git. Signed-off-by: Alessandro Zanatta <[email protected]>
75e5f05
to
1919051
Compare
Codecov ReportAttention: Patch coverage is
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. |
Signed-off-by: Alessandro Zanatta <[email protected]>
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! |
Thanks for implementing this enhancement. Will take a closer look. |
pkg/argocd/git.go
Outdated
if len(yCpySlice) != 1 { | ||
return errors.New("target parameter file should contain a single YAML document"), false | ||
} | ||
yCpy := yCpySlice[0] |
There was a problem hiding this comment.
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?
There was a problem hiding this comment.
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!
There was a problem hiding this comment.
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]>
pkg/argocd/git.go
Outdated
PreserveSeqIndent: true, | ||
} | ||
|
||
// Read input file |
There was a problem hiding this comment.
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?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updated!
pkg/argocd/git.go
Outdated
return err, false | ||
} | ||
|
||
// yCpy contains metadata used by kio to preserve sequence indentation, |
There was a problem hiding this comment.
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.
There was a problem hiding this comment.
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!
Signed-off-by: Alessandro Zanatta <[email protected]>
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 inpkg/argocd/git.go
works. It now useskio.ByteReadWriter
, which allows to preserve sequence indentation.I also had to slightly modify how the comparison is done:
kio
adds somemetadata.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 withkyaml
, 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 onkyaml
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