-
Notifications
You must be signed in to change notification settings - Fork 147
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
Add optional CI output to note #50
base: master
Are you sure you want to change the base?
Conversation
Instead of pulling CI output from a URL, add the ability to directly include the output in the note. This ensures the historial output is always available.
Thanks for your pull request. It looks like this may be your first contribution to a Google open source project. Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). 📝 Please visit https://cla.developers.google.com/ to sign. Once you've signed, please reply here (e.g.
|
First off, thanks for contributing. I really appreciate you taking the time and putting in the effort to make git-appraise better. The goal of this change is very similar to the discussion we've had in this issue regarding the long-term storage of static analysis reports. There is definitely value in storing the raw data inside of the git repository, but there is also risk of hitting scaling issues for very large projects (whether they be large in terms of codebase, change history, or both). For example, the build and test log for this commit is 273 lines long, and that's for a very simple build and test configuration. It's possible that this might still scale well if the build logs are largely similar to each other (and thus compress well), but I suspect that a lot of projects will have build logs that don't compress well (e.g. if they include a lot of data that is unique to each run, like timestamps). To be fair, this change does make the output field optional, so each project can decide for itself whether or not to populate it, and how much data to put in there. However, I worry that it's very easy for someone to accidentally hit a scaling issue and that it will then be difficult for them to back out of said issue. Alternatively, I wonder if we can enable the following scenario:
E.G. I'd like it if a user could easily drop their build-and-test detailed history while still maintaining the summaries. What do you think about the idea of storing the logs under a new git ref (for instance, something under the namespace "refs/notes/devtoolsdetailed/"), and then making the existing CI object include a reference to that? I will concede that this would be a much larger change than the current proposal, so I understand if you don't have time to get to that, but I do think it would be a safer change in the long run. There's also some ambiguity here about how the detailed logs should be stored. For instance, it could be a single ref holding all logs, or separate refs. I suspect our best bet would be to let the build runner define that, and make the CI object specify enough information to support multiple scenarios. If we go with this route, then I think the minimum amount of information the CI object would have to store is:
What do you think? |
@@ -170,6 +178,7 @@ func PrintDetails(r *review.Review) error { | |||
fmt.Printf(reviewDetailsTemplate, r.Request.ReviewRef, r.Request.TargetRef, | |||
strings.Join(r.Request.Reviewers, ", "), | |||
r.Request.Requester, r.GetBuildStatusMessage()) | |||
printBuildStatusOutput(r) |
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.
This should probably not be displayed by default (that would be very verbose), but rather limited to the case of a user passing in a special flag.
Specifically, I mean something like what we are doing for displaying a diff only if the --diff
flag is passed in.
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.
This should probably not be displayed by default (that would be very verbose), but rather limited to the case of a user passing in a special flag.
Specifically, I mean something like what we are doing for displaying a diff only if the --diff flag is passed in.
That makes sense, I will add an appropriate flag
That makes sense, would you be okay with storing those detailed notes as plain text? I was intending to have my static analysis tool, in this case puppet, create a puppet noop output for each commit. I would then like to be able to view each individual commit along with the ci output, using just
I am willing to give it a go.
What about an array of refs & an array of SHA1 hashes? |
CLAs look good, thanks! |
That sounds reasonable; the log is just a blob, and git already has an object type for blobs, so maybe we can just use it as is. There are complications, though, for distributing the blobs (see below).
That seems like a perfectly reasonable goal. I'd actually go further and just use the ref "refs/notes/commits", which is the default notes ref. The reasons I say that are:
That brings us back to the question of distributing the blob with the log contents to the various clones of the repository. What we need is a ref that someone can fetch from a remote (e.g. The bit of difficulty is when we have two different writers for a note on the same object under the same notes ref. We need to have some way of combining the contents from both writers. The current formats do this by using the Alternatively, we could use a different notes ref for each CI runner. That might still have issues, though, if a single CI runner tests the same commit twice. However, the more I think about it, the more that I suspect that when you run If we went with this overwrite approach, then you'd want your CI runner to:
On the client side, we'd just have to do a fetch of the notes ref from the origin to some non-conflicting location. If the user wanted to show these blobs in the output of Sorry that this response was long and rambling, but there are subtle complexities here and I want to make sure that however we address those complexities still works for your use case.
Thank you, I really do appreciate you volunteering your time and effort to make the tool better.
The CI notes are already an array for each commit (e.g. each commit can be tested multiple times with the summary of each run reported), so I don't think that is necessary. That being said, if I'm overlooking something please let me know. |
Instead of pulling CI output from a URL, add the ability to directly
include the output in the note. This ensures the historial output is
always available.