Once again, I’ve let my blog gather dust. And the comments have been piling up. And the emails have been rolling in. And I’ve been silent.
Sorry about that!
I’ve been pretty heads-down lately – here’s what’s going on:
The address book work I was talking about has been put on a tiny bit of a backburner as I deal with two more pressing Thunderbird projects, namely, finishing up the Account Provisioner (a service that offers you email addresses if you don’t already have one) and Tabs on top (a part of the general UX refresh that Thunderbird is working towards)
About the address book – I’ve received a bunch of email making suggestions and asking for things. That’s great! I’ll comment on that shortly – I just need a little more time to clear Account Provisioner and Tabs on Top off my plate.
Probably what rang out loudest for me was that I don’t really have any data on how real users actually use Thunderbird’s address book. I know how I use it, but that’s about it. In fact, I talked a Thunderbird user the other day who didn’t even know that the Thunderbird address book existed. Go figure.
And here I went and jumped the gun, and tossed together some mock-ups.
If there’s anything that my grad supervisor Greg Wilson taught me, it’s not to jump to conclusions (or mock-ups) when we don’t have any data to back it up. I’m a scientist, damn it, and that’s just how we roll.
Credit: http://cowbirdsinlove.com/46
Firefox has this great add-on called Test Pilot that lets Firefox users volunteer to have data periodically collected from them. Work to get Test Pilot working for Thunderbird is underway, and I think that’d be an awesome tool for gathering feedback about how users use the address book.
Some questions I’d want answered, right off the top of my dome, in no particular order:
Does anybody actually use Thunderbird’s address book?
When someone is using the address book, what are they likely doing?
Looking for a contact?
Sorting and organizing their contacts?
Creating or editing contacts?
Other?
Do people use mailing lists? If so, how many do they tend to have?
How many address books do people tend to have?
How many address books do people want to have?
How many contacts to people tend to have in their address books?
Is it important for people to be able to group their contacts into sets, like “Family”, “Friends”, “Acquaintances”, “Employees”, “Co-workers”, etc?
Given several address books, where each address book has some large number of contacts, how quickly can an individual contact be found?
How much switching back and forth from mouse and keyboard is required to create a new contact, or to edit an old contact?
How important is it for Thunderbird’s contacts to be synchronized with other contact services, like Google Contacts or the OSX address book?
Or is it sufficient just to import them?
How important is it for Thunderbird’s contacts to be synchronized with user’s mobile devices?
On average, how long does it take to create a new contact?
On average, how long does it take to edit a contact?
On average, how much time are users spending in the address book?
What fields do most users want to associate with a contact?
What are the top 10 complaints about Thunderbird’s address book?
What are the top 10 best things about Thunderbird’s address book?
What are some other questions I should try to get answered?
UPDATE (Aug 29 – 10:00EST)
I’ve gotten some awesome feedback on this post, and some new questions to add to my list. Here they are, in no particular order:
What is the main way in which Thunderbird users use and manipulate their address books?
Through the main address book interface
Through the contacts sidebar in the compose window
Through the inline contact editor within a message header
Other?
If the answer to the above is anything other than 1, is it possible that the address book manager is not needed? Or does not need to be as complicated as it already is?
How many duplicate contacts does the average user possess (where a duplicate contact is a contact with the same e-mail address, or possibly the same name)
How frustrating is it to add a contact in Thunderbird?
How frustrating is it to edit a contact in Thunderbird?
How frustrating is it to search for a contact in Thunderbird?
How often do users want to create a contact based on a pre-existing one? Example – creating co-workers, with similar fields for work addresses, etc, but different names, phones, etc.
So a few days ago, my official grades for my M. Sc. rolled in. That same day, I went to the Bahen Centre, turned in my desk keys, got my keycard authorization revoked, and scheduled my computer for erasure.
It felt like some pretty big steps. There was a palpable sense of finality. I was out. It was over.
The University has played a big role in my development, and despite all of my moaning and complaining over the years, I’m glad I went, and I’d do it again.
But not right now.
Graduate school almost didn’t happen for me, and I have two very important people to thank for making that happen: Karen Reid and Greg Wilson.
I still fondly remember when you cornered me during that codesprint in 2009, and convinced me to try graduate school. I don’t regret it. It was the right decision. So thank you both so much for convincing me, and giving me the chance, and thank you Greg for supervising, and guiding me through.
I learned lots. I had fun.
Shakespeare wrote that brevity is the soul of wit. Well, I
A major part of my Master’s degree requirements was my research paper. If you heard me lament over the past year or so about my “thesis”, I was referring to this research paper.
Anyhow, after lots of hard work, my research paper was finally signed off by my supervisor, Dr. Greg Wilson, and second reader Dr. Yuri Takhteyev. A huge thanks to both of them!
Here’s the abstract, followed by a download link for the PDF. Enjoy!
Abstract
Peer code review is commonly used in the software development industry to identify and fix problems during the development process. An additional benefit is that it seems to help spread knowledge and expertise around the team conducting the review. So is it possible to leverage peer code review as a learning tool? Our experiment results show that peer code review seems to cause a performance boost in students. They also show that the average total peer mark generated by students seems to be similar to the total mark that a graduate-level teaching assistant might give. We found that students agree that peer code review teaches them something – however, we also found they do not enjoy grading their peers’ work. We are encouraged by these results, and feel that they are a strong motive for further research in this area.
This semester, we saw some outstanding work for both projects. Lots of great students, lots of good code, lots of leaps forward.
I’m looking forward to helping out next semester with UCOSP.
I won’t be doing it as a paid teaching assistant though. Why? Well…
I’ve finished school
My research paper was signed off by my two readers, and I just wrote my last final exam a few nights ago. Unofficial grades have been posted, and I’ve passed what I needed to pass.
So that’s that – I’m a Master of Computer Sciences, I guess. Awesome!
I got a job!
I’ve been hired by Mozilla Messaging to work on the Thunderbird project! I’m 100% psyched about this opportunity, and look forward to peeling into the code. An added bonus: since Thunderbird is an open-source project, I’m absolutely free to discuss the code and the various things I’m doing with it. No NDAs for me! So stay tuned – I’ll have lots to say about Thunderbird and the Mozilla Framework code. Just give me some time to wade through it.
Zihuatanejo
It’s been a pretty long road. I’ve been in school, in one form or another, for over two decades. It’s strange that it’s over. I’m extremely excited about my next adventures, but I think I’m going to miss school.
In 1966, Andy Dufresne escaped from Shawshank prison. All they found of him was a muddy set of prison clothes, a bar of soap, and an old rock hammer, damn near worn down to the nub. I remember thinking it would take a man six hundred years to tunnel through the wall with it. Old Andy did it in less than twenty. Oh, Andy loved geology. I imagine it appealed to his meticulous nature. An ice age here, million years of mountain building there. Geology is the study of pressure and time. That’s all it takes really, pressure, and time. …Andy crawled to freedom through five hundred yards of shit smelling foulness I can’t even imagine, or maybe I just don’t want to. Five hundred yards… that’s the length of five football fields, just shy of half a mile…
Andy Dufresne – who crawled through a river of shit and came out clean on the other side.
I know, I know. I left you all hanging at the edge of your seat with my last blog post, and I still haven’t posted my idea for recognizing good code review.
I’m bogged down with school work, and I’m aiming to have the first draft of my research paper done next week. So that’s taking 100% of my resources.
While the benefits of code review are proven, documented, numerous and awesome, it doesn’t change the fact that most people, in general, don’t like doing it.
I guess code review just isn’t really all that fun.
So a few months ago, I broadcast the idea of turning code review into a game. It was my way of trying to mix things up – “let’s add points, and have reviewers/developers competing to be the best participant in the code review process”.
Well, if there’s one thing that my supervisor Greg has taught me, it’s how I shouldn’t rush headlong into something before all of the facts are in. So before I decide to do something like game-ifize code review, I should take a look at some prior work in the area…
In particular, check out the following slide-show. Flip through it if you have the time. If you don’t have the time, scroll down, where I get to the salient point with respect to game-ificating code review.
Sebastian seems to be saying that adding points to apps and trying to incite competition does not make something a game. If it did, then this should be countless hours of fun.
Without play, there is no game. Points do not equal a game. It’s not nearly that simple.
Free Pizza and Pop
I’m going to divert for a second here.
Last week, a company set themselves up a couple of booths in the lobby of the Bahen Center where I work. They were there to recruit university students to work for their company – either as interns, or full-timers.
They were also handing out free pizza and pop.
Needless to say, I wanted a few slices – but I figured it would be polite if I engaged them in conversation before waltzing off with some of the free food and drink they’d brought.
So I sparked up a conversation with one of the recruiters, and he told me about the company. I’m going to call this recruiter Vlad.
I ended up gently steering the conversation towards code review, and I asked my inevitable question:
“So, do you guys do code review?”
I felt like a dentist asking a patient if he’s been flossing. Vlad waffled a bit, but the general impression was:
“Not as much as we should. We don’t have a prescribed workflow. It’d be hard to persuade all of the teams to do it.”
And then we started talking about code review in general. It turns out that Vlad had worked in a few companies where they’d done code review, and he always felt a little short changed. He said something along the lines of:
“I never felt compelled to do reviews. They just sort of happened…and I did it, and it felt like…unrecognized effort. I mean, what’s the incentive? Do you know what I mean? There’s incentive for the software, but I’m talking incentive for me. And some people did really lousy reviews…but my reviews were treated the same as theirs. I didn’t get recognized, and didn’t get rewarded if I did a good review. So it was hard for me to do them. I want to be recognized for my good reviews, for my good contributions.”
I wish I’d had a tape-recorder running so I could have gotten Vlad’s exact words. But that’s what I remember him saying.
Feedback and Recognition
Maybe instead of trying to game-ulize code review, I can instead hear what Vlad is saying and work off of that.
With the code review that Vlad participated in, all of the feedback went to the code author, and none went to the reviewers. And the reviewers are the ones who are doing all of the heavy lifting! As a reviewer, Vlad also wants feedback, and recognition for code review done well.
There’s a company in Toronto that specializes in feedback like this. They’re one of the major players in the Toronto start-up scene, and have built a pretty sweet suite of tools to facilitate quick and easy feedback/recognition.
The company is called Rypple. And maybe that’s the name of the application, too. (checks website) Yeah, it’s both.
So Rypple has this feature called Kudos that let’s people publicly acknowledge the good work of their team.
Normally, I don’t pimp companies. And it upsets me when people comment on my blog, and their sub-text is to try to sell their product or service. However, I think this video is relevant, so I’m posting their demo video so you can see how Kudos work:
So Rypple’s idea is to have a feed that the team subscribes to, and publicly display things like Kudos. The badges for the Kudos are also limited in how many you can give per week, so they’re a valuable commodity that can’t just be handed out all over the place. Cool idea.
So there’s one approach – use a service like Rypple to give your reviewers better feedback and recognition.
Or maybe we could build an extension for Review Board that does something similar, and more oriented around code review.
It’s not oriented like a game, like I had originally envisioned. But somehow, I think this idea has more meaning and traction than just “adding points”.
More on this idea in a few days. But please, comment if you have any thoughts or ideas to add.
So I wrote my (hopefully) last mid-term ever last night, and in celebration, I thought I’d put together a little video showing off the issue tracking feature I’m hoping to put into Review Board.
It’s still in it’s very early stages. The code hasn’t been reviewed. I’m still really really open to suggestions and feedback on this. So please, comment here, or on the reviewboard-dev list.
Persons attempting to find a motive in this narrative will be prosecuted; persons attempting to find a moral in it will be banished; persons attempting to find a plot in it will be shot.
By order of the author,
Per G. G., Chief of Ordinance