Comment 0 for bug 1018013

Revision history for this message
Daniel Berrange (berrange) wrote :

The current script that integrates GIT commits merged from Gerrit, with the bug tracker has sub-optimal behaviour when deal with fixes that span across multiple commits. When preparing a patch series is it natural to note the bug number in all of the patches in the series which are directly relevant. When updating the bug status to 'Fix committed', however, the Gerrit hooks only consider each patch in isolation. So if 1 single patch out of a series is merged, but the others are not, the bug will get prematurely marked as 'Fix committed'.

The only current way to deal with this is to refrain from mentioning the bug number in all but the very last commit in the patch sequence. This is undesirable though, since the bug number is useful data for the GIT history, and we do want all patches related to the bug to be tracked as a whole.

The current Gerrit bug hook:

https://github.com/openstack/openstack-ci-puppet/blob/master/modules/gerrit/files/scripts/update_bug.py

matches on a regex

   bug_regexp = r'([Bb]ug|[Ll][Pp])[\s#:]*(\d+)'

So anything like

    Bug #NNNN

will cause the bug to be closed once commited.

I would suggest expanding the syntax to allow an (optional) qualifier to be prefixed eg

   Related bug #NNNN
   Resolves bug #NNNN

Any bug qualifier would cause the commit to be associated with the bug, but only the 'resolves' qualifier would cause the bug to be marked as 'Fix commited'. For compat with existing practice & easing of the "simple" non-patch series case, the lack of any qualifier would be treated as meaning 'Resolves'. So only people creating patch series, would need to use 'Resolves' vs 'Related' distinction

A completely different idea, would be to try and identify complete patch series in gerrit, and automatically "do the right thing"
 wit the bug tracker only marking it as resolved once the entire series is committed. I'm not sure how practical that is though, given Gerrits' limited understanding of patch series. eg could it detect this example:

  https://review.openstack.org/#/q/status:open+project:openstack/nova+branch:master+topic:bug/1003373,n,z

where all 5 patches were pushed to gerrit at once ?