All the brilliant people working on the same thing, at the same time, in the same space, and on the same computer - Woody Zuill
Last night was our first crack at a mob programming event with the Twin Cities Geekettes. As usual, we walked away with reminders of why we do this, why we push to get and keep women in the tech industry, why we want to build a welcoming and inclusive community, and why we keep plugging away when we find that **software kicks us in the a$$**. Because it never fails to do that.
We started out with a simple problem - implement the game of battleship. Throughout the evening, we asked questions, we wrote code, we learned, and we met new friends.
Just like any project, we learned that not everyone knew what the game of battleship is so we spent a couple minutes laying out the mission of the game and some terminology. We learned that it’s important to use the same language, and the people driving the process (our audience) had to learn how to communicate what they wanted, both from a business standpoint (SINK ALL THE SHIPS!) to a code and syntax perspective (Don’t forget that semi-colon!).
We didn’t know how much code we were starting with or what the intention was of the original programmer, which is exactly what happens in any project. The first few mobbers spent time sifting through the code to grasp it and to explain to the rest of us what was going on. Sometimes an audience member would contribute as well. As we got into it, mobbers spent a little more time writing code instead of analyzing the code and our velocity went up.
During the mob process, we had thought provoking questions that sparked a level of conversation that is frequently not happening in our day jobs:
* how do you know where to start?
* how do you break down a problem?
* what if we had tasked this problem out differently from the start?
* what if we started from scratch (a greenfield project) instead of existing code (a legacy codebase)?
* should we increase the scope of our work?
* should we refactor now or later?
* when do we write our tests?
* will that have good performance?
We learned the simple things like how to use new tools, like Codepen, the javascript console, and how to write a for loop in javascript. We learned the hard things like having a diverse team is beneficial, something that this industry struggles with every single day. We learned that diversity extends past gender and to age, skill, race, experience, the role you play on a team, and more.
And this all happened in the span of TWO hours.
What could you learn in two hours of mob programming?
Just imagine if you slowed down for two hours to experiment with mob programming on your next hard problem at work.
Check out what mob programming is all about here and watch a time-lapse of a day long mob programming session here.
Reposted with permission from www.jennapederson.com. Jenna Pederson has co-led the Twin Cities chapter of the Geekettes since early 2014. She is passionate about creating a welcoming and supportive tech community for Twin Cities tech women. Jenna is also the founder of 612 Software Foundry, helping small businesses and startups with technical strategy and implementation.