Mob Programming
Mob Programming
A Whole Team Approach
About the Book
"All the brilliant minds working together on the same thing, at the same time, in the same space, and at the same computer" - We call it "Mob Programming". With dual projectors, one computer, two keyboards, and a very collaborative approach we use this approach to super-charge our development efforts and deliver high value software quickly.
In this book we share our "Mob Programming" style. We'll cover the techniques we use in our daily work , how we discovered this way of working, the benefits we see from "Mobbing", the problems we've overcome, and how you can incorporate some of our ideas even though you don't have a way to adopt Mob Programming full time.
About the Contributors
Griffith

Bowler
Table of Contents
- Acknowledgements
- Part One: Introduction
-
1.1 What is Mob Programming?
- How We Started
- What’s in a Name?
- Why this Book?
-
1.2 Set the Stage for Great Things
- It’s About the Environment
- We Work Better when We Work Together.
- The Stage was Set
-
1.3 A View of the Room
- A little peek at what it looks like
-
1.4 See for Yourself
- Watch a video of a full day of work in only 3 minutes!
-
1.5 How We Discovered Mob Programming
- The Driver-Navigator Model
- The Coding Dojo Sessions
- Studying and Practicing Together
- The Next (In)Obvious Steps
- 1.6 Quick Start Guide
- Part Two: The Details
-
2.1 The Team
- The Mob Programming Team
-
2.2 The Workspace Setup
- Introduction
- The Area
- The Computer
- Projectors or Monitors
- Keyboard/Mouse
- Chairs and Tables
- Telephone and Email
- Ergonomics
- Private Work Area
-
2.3 The Driver-Navigator Model In-Depth
- The Navigators and Navigation
- The Driver and Driving
- The Consultation - The Pause for Clarity
- Conflicting Ideas
- An Example
- Rotating the Roles
- A Timer
- Summary
-
2.4 Why Would We Work This Way?
- There are Many Benefits from Working as a Mob Programming team
- It’s a Trick Question
- The Typical Answers
- The Real Answer: We Work this Way Because the Team Decided to Work this Way
- Provide a Safe Place Where We can Discover Awesomeness
-
2.5 How Can We Work This Way?
- A Principle to Live By
- It’s the People, not the Code
- Our Story
- Kindness, Consideration, and Respect
- Part Three: Productivity
-
3.1 The Productivity Question
- How Can Five People At One Computer Be Productive?
- Changing the question
- What we found with Mob Programming
- Another way to think about it
-
3.2 Problems That Faded Away
- It’s The System?
- A Backpacking Trip
- Management Overhead
- Working Well Together
- What’s Coming Up in the Next Chapters
-
3.3 Problem: Faulty Communications
- Communication problems are pervasive, numerous, and paralyzing.
- Problem: Getting Answers to Questions can take a lot of time.
- Problem: Communication by Email
- Problem: Communication by Documentation
-
3.4 Problem: Issues with Decision Making
- Decisions are a Good Thing
-
3.5 Problem: Doing More Than What is Barely Sufficient
- Should We Ever do More than Enough?
- Examples of “Too Much”
- How Mob Programming has Helped
- Conclusion
-
3.6 Problem: Technical Debt
- The Alligator in the Pond
- It Faded Away
- The Many Forms of Technical Debt
- Conclusion
-
3.7 Problem: Thrashing
- Distractions, Context Switching, Interruptions: This is Thrashing
- Thrashing of Programmers
- Who Gets Thrashed?
- Why is Thrashing Harmful?
- How it Faded Away for Us
- Recap
-
3.8 Problem: Politics
- Many faces of politics
- It Faded Away
-
3.9 Problem: Meetings
- “Please, sir, I want some more meetings.”
-
3.10 A Simple Cost Analysis of Mob Programming
- Sensitivity Analysis
- Summary
- References
-
3.11 The Power of Flow
- References
- Part Four: A Few Other Things
- 4.1 What is the Ideal Number of Team Members?
-
4.2 Continuous Learning
- Providing an Environment where Learning is “Amplified”
- Study and Practice Together
- Friday Afternoon Practice
- Mob Programming and Learning
- Our Morning Hour of Learning
- Amplifying Learning
-
4.3 Exposed
- The Fear of Being Exposed
- Why It Might be Frightening
- What can we do about this?
- Mistakes are Part of the Process
- This is Voluntary
- Conclusion
-
4.4 Ergonomics, Health, and Sanity
- Let’s Take Care of Ourselves
- Projectors, Chairs, Keyboards, and Screens
- Stretching, Talking Walks, Taking Breaks
- Preventing the Spread of Illness
- Sanity
- In Conclusion
-
4.5 Retrospectives: Reflect, Tune, and Adjust Frequently
- If You Only have Time to get Good at One Thing, Start with Retrospectives
- An Example of a Typical Retrospective
- An Affinity Mapping Example
- Give it a Name
- Here is What We Decided to Try
- A Daily Practice Period
- Another Retrospective, Another Step Forward: The 12 Days of Index
- Things to Notice
- The Takeaway
-
4.6 Turn Up The Good
- Something that Works Well: Turn Up the Good
- Solving Problems - What’s Wrong with That?
- Turn Up The Good
-
4.7 Relaxed and Sustainable
- This is Wearing Us Out!
- The Problem
- We Don’t Need to Be a Hero
- Take a Break
- Make it Sustainable
-
4.8 Barriers to Mob Programming
- My Manager Won’t Let Us
- We Don’t Have a Space to Do It
- We Don’t Know How to Get Started
- Our Teams Don’t Even Want to Pair Program
- The Tech Lead Coded While Everyone Watched
- We were Exhausted After a Few Hours
- We aren’t Really Very Agile.
-
4.9 Remote Mob Programming
- Introduction
- Advantages to Working Remotely
- Can We “Turn Up The Good” on Working Remotely?
- How do we do this?
- Are we Effective when we are Remote?
- Things to Watch Out For
- Exploring and Experimenting
- 4.10 Frequently Asked Questions
-
4.11 Do We Recommend Mob Programming?
- Everyone Wants to Know: Do You Recommend Mob Programming?
- To Whose Advantage?
- It is Not a Panacea
- If You Decide to Try It
- Part Five: Experience Reports
- 5.1 Teaching Mob Programming
- 5.2 Using Mob Programming as a Training Tool
-
5.3 Mob Programming for the Introverted
- Introduction
- Background
- Observations of Mob Life
- Mob Programming as an Introvert
- Change and Growth
- What I Have Learned
- Acknowledgements
- References
- 5.4 Corgibytes Adopts Mob Programming
- 5.5 Sticky Mob Programming
- Appendix 1 - The Agile Manifesto
- Appendix 2 - Twelve Principles of Agile Software
- Notes
The Leanpub 60-day 100% Happiness Guarantee
Within 60 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.
See full terms
Do Well. Do Good.
Authors have earned$11,826,004writing, publishing and selling on Leanpub, earning 80% royalties while saving up to 25 million pounds of CO2 and up to 46,000 trees.
Learn more about writing on Leanpub
Free Updates. DRM Free.
If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).
Most Leanpub books are available in PDF (for computers) and EPUB (for phones, tablets and Kindle). The formats that a book includes are shown at the top right corner of this page.
Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.
Learn more about Leanpub's ebook formats and where to read them
Top Books
Stratospheric
Tom Hombergs, Björn Wilmsmann, and Philip RiecksFrom Zero to Production with Spring Boot and AWS. All you need to know to get a Spring Boot application into production with AWS. No previous AWS knowledge required.
Go to stratospheric.dev for a tour of the contents.
Advanced Web Application Architecture
Matthias NobackThe missing manual for making your web applications future-proof
node-opcua by example
Etienne RossignonGet the best out of node-opcua through a set of documented examples by the author himself that will allow you to create stunning OPCUA Servers or Clients.
C++20 - The Complete Guide
Nicolai M. JosuttisAll new language and library features of C++20 (for those who know previous C++ versions).
The book presents all new language and library features of C++20. Learn how this impacts day-to-day programming, to benefit in practice, to combine new features, and to avoid all new traps.
Buy early, pay less, free updates.
Other books:
Introduction to Data Science
Rafael A IrizarryThe demand for skilled data science practitioners in industry, academia, and government is rapidly growing. This book introduces concepts from probability, statistical inference, linear regression and machine learning and R programming skills. Throughout the book we demonstrate how these can help you tackle real-world data analysis challenges.
R Programming for Data Science
Roger D. PengThis book brings the fundamentals of R programming to you, using the same material developed as part of the industry-leading Johns Hopkins Data Science Specialization. The skills taught in this book will lay the foundation for you to begin your journey learning data science. Printed copies of this book are available through Lulu.
Maîtriser Apache JMeter
Philippe Mouawad, Bruno Demion (Milamber), and Antonio Gomes RodriguesToute la puissance d'Apache JMeter expliquée par ses commiteurs et utilisateurs experts. De l'intégration continue en passant par le Cloud, vous découvrirez comment intégrer JMeter à vos processus "Agile" et Devops.
If you're looking for the newer english version of this book, go to Master JMeter : From load testing to DevOps
OpenIntro Statistics
David Diez, Christopher Barr, Mine Cetinkaya-Rundel, and OpenIntroA complete foundation for Statistics, also serving as a foundation for Data Science.
Leanpub revenue supports OpenIntro (US-based nonprofit) so we can provide free desk copies to teachers interested in using OpenIntro Statistics in the classroom and expand the project to support free textbooks in other subjects.
More resources: openintro.org.
Aprendiendo Git
Miguel Angel Durán GarcíaGit no es complicado... ¡Si lo entiendes! 😜
¿Sientes que sabes usarlo porque has memorizado todos los comandos que necesitas? ¡Pero no entiendes qué hace cada cosa y por qué! Así es normal que, cuando exista un problema, te cueste resolverlo.
¡Con este libro vas a entender de una vez por todas todo lo que es Git y cómo sacarle provecho!
Discrete Mathematics for Computer Science
Alexander Shen, Alexander S. Kulikov, Vladimir Podolskii, and Alexander GolovnevThis book supplements the DM for CS Specialization at Coursera and contains many interactive puzzles, autograded quizzes, and code snippets. They are intended to help you to discover important ideas in discrete mathematics on your own. By purchasing the book, you will get all updates of the book free of charge when they are released.
Top Bundles
- #1
CCIE Service Provider Ultimate Study Bundle
2 Books
Piotr Jablonski, Lukasz Bromirski, and Nick Russo have joined forces to deliver the only CCIE Service Provider training resource you'll ever need. This bundle contains a detailed and challenging collection of workbook labs, plus an extensively detailed technical reference guide. All of us have earned the CCIE Service Provider certification... - #2
All the Books of The Medical Futurist
6 Books
We put together the most popular books from The Medical Futurist to provide a clear picture about the major trends shaping the future of medicine and healthcare. Digital health technologies, artificial intelligence, the future of 20 medical specialties, big pharma, data privacy, digital health investments and how technology giants such as Amazon... - #4
Pattern-Oriented Memory Forensics and Malware Detection
2 Books
This training bundle for security engineers and researchers, malware and memory forensics analysts includes two accelerated training courses for Windows memory dump analysis using WinDbg. It is also useful for technical support and escalation engineers who analyze memory dumps from complex software environments and need to check for possible... - #5
Software Architecture
2 Books
"Software Architecture for Developers" is a practical and pragmatic guide to modern, lightweight software architecture, specifically aimed at developers. You'll learn:The essence of software architecture.Why the software architecture role should include coding, coaching and collaboration.The things that you really need to think about before... - #6
Practical FP in Scala + Functional event-driven architecture
2 Books
Practical FP in Scala (A hands-on approach) & Functional event-driven architecture, aka FEDA, (Powered by Scala 3), together as a bundle! The content of PFP in Scala is a requirement to understand FEDA so why not take advantage of this bundle!? - #10
Learn Git, Bash, and Terraform the Hard Way
3 Books
Learn Git, Bash and Terraform using the Hard Way method.These technologies are essential tools in the DevOps armoury. These books walk you through their features and subtleties in a simple, gradual way that reinforces learning rather than baffling you with theory.