Re: Refactoring the Review Process

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 4/22/20 5:25 PM, Darrick J. Wong wrote:
> Hi everyone,
> 
> Writing and reviewing code in isolation hasn't always served me well.  I
> really enjoyed my experiences developing the reflink code (~2015) being
> able to chat with Dave in the evenings about the design of particular
> algorithms, or how certain XFS structures really worked, and to learn
> the history behind this and that subsystem.
> 
> Returning to first principles, I perceive that the purpose of our review
> processes is to make sure there aren't any obvious design flaws or
> implementation errors in the code we put back to the git repo by
> ensuring that at least one other XFS developer actually understands
> what's going on.
> 
> In other words, I am interested in testing the pair programming
> paradigm.  Given that we have zero physical locality, I suspect this
> will work better with an interactive medium and between people who are
> in nearby time zones.  I also suspect that this might be better used for
> more focussed activities such as code walkthroughs and reviews.  Still,
> I'm willing to entertain the possibility of using this as a second means
> to get a patchset to a Reviewed-by.
> 
> I also speculate that this might be a good mentoring opportunity for us
> to trade productivity tips and disseminate 'institutional' knowledge
> between people.  I for one am happy to help others learn more about the
> code base in exchange for learning more about the parts of XFS with
> which I'm less familiar.  (I bet Allison knows more about how xattrs
> work than I do at this point...)

Just to chime in, I like this idea.  I think that it's a fairly open-ended
suggestion, as this could be anything from:

* True, traditional pair-programming for new work
* Dividing up tasks for larger projects, and cross-reviewing each others work
* High-bandwidth review of existing work by interacting directly w/ patch author
  in real time on irc or video
* ??? other ideas

In the first couple cases, this might result on patches first appearing on the
list with a "pre-existing" Reviewed-by that came out of that teamwork.

As a result we should probably consider a policy that patches remain on the list
for at least $X days to allow further comment by "3rd parties" if the list is to
remain (as it should) the ultimate forum for patch acceptance.

The other thought I have is that while pairing in any of these ways will be an
excellent growth opportunity (in general, or in a specific area of code) we should
be somewhat mindful of "lopsided" pairing, i.e. having a guru paired with a total
newbie for an extremely large, complex project may not be the best idea, but that's
probably self-evident.  Such teamwork will probably somewhat naturally select into
logical pairings depending on the task at hand.

So, for myself, if anyone wants to review anything I've written in real time, or
would like me to collaborate on their upcoming work, I'm happy to do so within
the limits of my schedule and bandwidth.  :)

Thanks,
-Eric



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux