TL; DR Mob Programming benefits need more study
Photo by Jason Goodman on https://unsplash.com/@jasongoodman_youxventures

TL; DR Mob Programming benefits need more study

According to two different recent papers Mob Programming: A Systematic Literature Review, July 2019, and Mob programming: From avant-garde experimentation to established practice (preprint PDF) May 2021, more research is needed to validate the claimed benefits of Mob Programming. Both research teams conducted a literature review of existing publications on the topic, with the later paper also supplementing their analysis by conducting interviews with a team of practitioners.

Both research teams were able to find a limited number of publications on the subject (10, 11). Of those papers most are experience reports, which focus on what the practice is rather than on why using this practice is beneficial. There were no evaluation papers or validation papers that would evaluate or validate the claimed benefits of Mob Programming.

A group of people in a conference room arranged for mob programming with a big monitor at the front of the room.

Most papers have a common definition of what Mob Programming is: Three or more individuals writing code together using one keyboard and a large monitor. There is a driver, a person sitting at a keyboard doing the typing, a navigator directing the driver, and observers watching what is going on and potentially pointing out issues. The driver rotates frequently between 5-10 minutes. Most papers site the work of Woody Zuill, the inventor of Mob Programming, Mob Programming – A Whole Team Approach.

Both research teams concluded that there is a need for more empirical evidence to support claims of lead time and productivity improvements.

...The after effects of MP were not analyzed in depth. Instead surveys and personal opinions of mob programmers were used. The results show effects such as improved code quality and increased productivity. However, actual scientific proof (only personal opinions) does not exist… (Shiraishi, Makoto, et al.)
...While significant claims have been made regarding improved productivity, learning, lead time optimization and quality, quantitative data would be helpful in supporting these claims… (St?hl, Daniel, and Torvald M?rtensson.)

As well as a need for more empirical evidence to support claims of improved teamwork and communication:

...The experience papers all reported that teamwork is enhanced through MP. The results, which are not actual research on team work, consist of surveys answered by participants. Surveys are most likely opinions and do not resemble research or experimental conclusions… (Shiraishi, Makoto, et al.)
...Mob programming brings the social dynamics of the team to the fore. A deeper understanding of them is important both for the efficacy of the practice and the well-being of the practitioners… (St?hl, Daniel, and Torvald M?rtensson.)

What does this mean to practitioners?

If you are thinking about trying Mob Programming with your team you will find several experience reports that describe the process and setup. You will not be able to find any quantitative data to support potential benefits to your team. As reported in several sources your team will “feel more productive” and will be able to “present credible arguments” about lead time optimization. However, you should not expect any significant, measurable, improvements in productivity. As St?hl, Daniel, and Torvald M?rtensson put it in their paper:?

...we argue that if the actual increase in productivity had been anywhere near the amazing figures sometimes reported … this would have been abundantly clear to everybody in the team. In other words, there is reason to believe that any productivity gains in the studied team were modest…


Guillermo Espinola Orci

Creating better software by creating software better! Party starter! Always Sparking Up conversation

1 年

IME is the more effective way to sync the team and distribute the knowledge of the project. I need no more study, I live it very often!

回复
Matthew Chaplain

software engineering is a team sport

2 年

I think it's important not to fall into a nirvana fallacy here: "this isn't proven good in all cases, therefore let's never use it." Just as there are insufficient studies showing mob programming more effective than solo programming, so is it that there are insufficient studies showing solo programming more effective than mob programming. It's just that we've been doing solo programming for longer, so it gets a default "win", but maybe it shouldn't.

Interesting. I wonder how much the productivity gains (if there are any) rely on this being an in-person setup. I'm sure you could make this work in a remote environment, but it seems heavily dependent on the socail aspect of being there in person.

回复

要查看或添加评论,请登录

社区洞察

其他会员也浏览了