Crunch is the mythical process from the old waterfall development days where software isn't done for a deadline and the team needs to work long hours, even weekends right at the end to get it done. The last known example of crunch occurring in the wild was in 1982 on the development of (ironically enough) an overtime tracking system in COBOL. Since then, we all work on two-week sprints with extreme agile pragmatic scrum efficiency and don't have any bugs that we didn't find with our 100% unit test coverage (which we wrote before the code, obviously).
Ok, so that's total bullshit. Crunch happens a lot in the game industry, enough that you plan for it. The quasi-whistleblowing ea_spouse article even referred to "pre-crunch" starting at the beginning of a game cycle.
So the questions are: why does crunch happen, and what can we do to
In the game industry, especially console games, one factor that amplifies crunch is the fact that once you ship a product, that's it. It's done. There's no v1.1. You can't release a beta to select customers to let them find bugs for you, and you can't respond to bug reports with "will be fixed in a later release." Of course, that's not necessarily true with the current generation of consoles -- on the Xbox 360 and PS3, you can patch the game after it ships. That isn't always as simple as you might think, though. First, patching costs money -- not just for the development of the patch itself, but the money you pay Microsoft or Sony to host the patch for you. Second, unless you release your patch on or before launch day, the first batch of users (and reviewers) plays the game bugs and all. Third, trying to get a bug waived by Microsoft or Sony saying "we'll patch it" doesn't generally go over very well. And lastly, it's not just a simple matter of rolling out a patch: the patch itself needs to be approved, and in certain cases your entire game gets retested.
But this isn't the entire reason why crunch happens. We crunch because the product isn't done, and it's supposed to be. So, looking at it that way, there's two reasons. Is it because the product isn't done, or because the product isn't supposed to be done?
Realistic schedules, deliverables, and deadlines are crucial, and lying to yourself doesn't end up helping anyone. If you're a year out from shipping with six months left in the schedule, you're still a year out. Furthermore, if you're a year out with six months left, so you add 20 people to your team of 30 and tell them to work 72 hour weeks, you might save three months, at the high end. Managers need to be aware that the man-month is, in fact, mythical, and that no amount of extra resources or extra time will change that.
Okay, managers aren't completely to blame, as much as we'd like them to be. Why do we have a million bugs that crop up right at the end of a project? Most software is not written from scratch, and games are (generally) no exception. Especially for sequels, the majority of the code base comes from a previous game. So when I see a comment that says:
// HACK: jsmith 12/12/02 workaround for TTP #1234I know a few things. More than five years ago, there was a bug in a bug tracker that no longer exists, and someone named jsmith who doesn't work for the company anymore hacked in a workaround for it. What was the bug? What was the hack? I have no idea. This kind of code makes software more fragile and more difficult to maintain. I'm guilty of doing this too -- because it's 2 in the morning and we're submitting next week and I've got 14 A bugs and I want to get it the hell done so I can get my four hours of sleep. These things happen and (without getting rid of crunch) there's no way to avoid them. But the real problem is that they cause crunch in the project that inherits them. Hacks beget hacks, and hacks lead to crunch.
With a two-fold problem, we need a two-fold proposal. On the managerial side, we need people who aren't going to lie to themselves or anyone else about what's possible in a given timeline. A lot of being able to predict how long something is going to take comes from experience. If you're not experienced, ask someone who is, and -- this is the key point here -- TRUST THEM. It doesn't help anyone to have delusions about when you're going to ship. If you're not going to ship on time, either change the definition of "on time" or start cutting features until you will ship on time. This technique does not work during crunch, obviously, but the whole purpose here is to avoid or shorten that as much as possible.
And as for us. At the beginning of the project, start unhacking. Fix all those hacks the right way. Now that you know what problems there were with your initial design, refactor it to take those into account.
Of course, it would benefit everyone to be a little more agile, but when you're working on a project for two years in order to make one release, that's not always possible.
2 comments:
Do games developers find themselves having to compromise scope in favour of quality a lot of the time, then? The interesting thing is that pretty much exactly what sells a lot of games (the crucial "features") are at odds with the most critical tenets of their development process.
Are practices like automated testing, static checking (maybe even with checks for "HACK" or "TODO" comments?) and continuous integration common in games development? They seem as though they're the sort of thing that you often see touted to help monitor this sort of thing, I'd be interested to hear your perspective on them.
I find that my crunch times come from poor estimates created by managers planning for perfect-world scenarios that don't exist. The problem with coding is a lot of time is spent handling unpredictable bugs with no way to accurately set a time for resolution. It works when it works. I can't convey this to managers, and thus I give poor estimations of my own work because "hey, I've done this a million times before".
Then the bugs hit and it's crunch time, yet again.
Post a Comment