Pair Programming in the Time of Covid
01.13.2022 | Culture | Kate Courtney
What was pair programming in the before times?
Pair programming is a way to develop software. It used to involve two software developers sitting down at one workstation and writing code together. There is usually a “driver” who is typing and “steering” the mouse and a “navigator” who is thinking more strategically about the big picture of what the code should be doing. You switch roles constantly and at the end of the day, you have a software product that’s better than if one person sat down by themselves and wrote it and then another person sat down by themselves and reviewed it.
I don’t know about you, but asking me to sit down next to someone and share a keyboard, mouse, and general air with them sounds like a great way to catch all their germs. And that’s not really something I’m interested in doing right now.
So how do you pair program remotely?
Personally, usually in sweatpants with at least one cat trying to attack the mouse on my screen.
But seriously, it’s a lot harder to pair remotely, but that doesn’t mean you shouldn’t try. Here’s what I’ve found works for me:
Be intentional about pairing
It’s much easier to scroll through reddit, or go start something in the slow cooker, or do some online shopping when you’re alone in a room than it is when you’re sitting next to someone sharing a screen. I do much better when I put my phone on my desk, with the screen down. I’ve also learned I do better when I close non-pairing related tabs. I remind myself that I’m pairing and that I need to be an active participant.
Find a good screen-sharing program
At Focused Labs, we’ve settled on Pop. I really like Pop because it gives me the ability to both draw on and take control of my partner’s screen. This is really useful because I think we’ve all been in meetings where we’re trying to tell somewhere what to click on and we have to say, “okay click on Edit, now it’s the third item, nope you went to far, no a little to the left, okay too far left, THAT’S IT!” It’s so much easier for everyone to just circle it with your mouse, or click on it for them.
It’s also great when it’s time to switch roles. You don’t have to push everything to git and have your pair pull it, you can just type on their screen.
There’s a lot of non-verbal communication that humans take place in that we simply cannot do over Pop (or zoom, or tuple, or whatever you choose to use). Because of that, it’s really important to use what we do have. And that’s our video and our words. I think it’s super important to have your video on when pairing. Your mouth might be saying, “oh sure, I understand totally what you’re saying.” But your face might be telling a very different story. If I can only hear your words, and not see your face, I’ll move on thinking we’re on the same page.
On that same idea, tell the truth. If you’re lost, say so. There’s nothing wrong with that. Everyone processes information differently. Tell me you’re stuck so I can think of a different way of explaining what I’m talking about. Also, if I’m making a bad decision, don’t just make a face but say nothing. Tell me (kindly) why you think I’m making a bad choice. Maybe I’m missing some context, maybe there’s some secret to the programming language I don’t know yet, or maybe my cats are desperately trying to jump onto my keyboard, so I don’t have full mental focus.
I also realize this isn’t always possible. Some days my internet is just bad, and I can’t turn my camera on, or my router will crash. (And yes, I’ve called my ISP about this.) When that happens, I explain why my camera is off, and I put more effort into using my words and staying engaged.
The idea of sitting in one spot for 4 hours talking to one person doesn’t sound fun. Schedule in some breaks. Go get coffee, take a walk, have a snack, go to the bathroom. We’re all just humans, we need some rest. Also, if you’re really stuck on something, and both people’s frustrations are getting high, stop. Take some time to do something else, and then try again.
Give everyone grace
There is a big difference between pair programming sitting next to one another and pair programming sitting in different states, time zones, and maybe even continents. Remember that we’re now spending time in our coworkers homes, that’s weird. Try your best and trust that your pair is trying their best. This is all uncharted territory, and there are going to be some growing pains, the best we can do is the best we can do.
01.12.2022 | Blockchain Web3 Tutorial Backend | Austin Vance
The "_Non-Fungible_" attribute of an NFT has some remarkable properties that allow smart contract developers to store state in a permissionless manner and enable that...
01.03.2022 | Blockchain Testing Web3 | Austin Vance
There are two ways: you can deploy "mock contracts" or you can use a mocking library. There are tradeoffs, but for this post I am going to focus on using a Smock's...
06.30.2021 | Culture | Katy Scott
At Focused Labs, collaboration is key to how we work together; it helps our teams learn from each other, brings us closer and helps us become more efficient...
06.23.2021 | Culture | Austyn
Late-night feedings and diaper changes, the 3-4 month sleep regression, teething, and a growth spurt all mean I'm getting less sleep than...
05.12.2021 | Culture Backend Frontend | Ryan Taylor
Temporarily disrupts "normal" business operations and allow self-organized teams to rapid prototype around their interest areas
04.27.2021 | Culture | Erin Hochstatter
Several years ago, I'd been trying to find an approach to software consulting that made sense for me [...]