The Many Hats of Software Development

Bored with coding? See what other key processes there are to getting your project to users and you might discover a new career path along the way.

"I am for all waters": I am a Jack of all trades, can turn my hand to anything, a good all-round man. Like a fish which can live in salt or fresh water.
Brewer's Dictionary of Phrase & Fable

There's more to being a good developer than just being able to pound out syntactically correct code. All the clever hashing algorithms and well-commented procedures in the world won't get a product out the door (or on to the end user's desk, if you're working in a corporate setting). If you work in a large company, you may not need to worry about this too much. There will be scores of other people in the software production chain who will work together with you to make sure the code turns into an application.

But the situation is different in small shops. Sometimes a team of two or three developers has to do it all, perhaps with the help of a secretary and a tester. Some software, of course, gets written by lone-wolf independents who have to do the entire job, from concept to packaging. If you aspire to work in such an environment, there are plenty of skills you can pick up to become more employable and useful to a small software organization.

Even if you're working for BigCo, Inc., you might not want to be too complacent about relying on your coding skills for your entire career. Code fashions change, and today's high-demand language might be tomorrow's boat anchor. (Seen many ads for Turbo Pascal programmers recently?) Combine that with the ever-present threat of outsourcing and you might find it worthwhile to expand your skill set as a career safety net.

Here, then, are some ideas for directions in which the good coder might choose to explore. As a bonus, none of them involve going into management, a fate which is often viewed as worse than death in our industry.

Developer Central Newsletter
Want to read more of Mike's work? Sign up for the monthly Developer Central e-newsletter, including product reviews, links to web content, and more, at http://lists.101com.com/nl/main.asp?NL=adt.

Design It and They Will Build
One of the easiest ways to enhance your skills is to get more involved in the design end of the software process. This will move you towards being a software architect, though there's some debate about what exactly a software architect does. Still, if Bill Gates' current title is "Chief Software Architect," it can't be all bad.

One way to move more into the architecture is to become familiar with the Unified Modeling Language. UML is an abstract, graphical language for specifying the structure of software, which is supported by an ever-growing variety of tools. Good resources for getting started include Sinan Si AlLhir's Learning UML (O'Reilly) and Jason T. Roff's UML: A Beginner's Guide (McGraw-Hill/Osborne). The Object Management Group's UML Resource Page (http://www.omg.org/uml/) is a good online starting point.

But don't focus on UML too much: The tools are not the job (and there are other ways to document the structure of an application, no matter how universal UML aspires to be). To be a good software architect, you need to understand how good applications are put together. This is an area where you need to hit the books, especially if you didn't go through a formal computer science academic program. Start with the classic Design Patterns by Erich Gamma et al (Addison-Wesley) and then take a look at Martin Fowler's Patterns of Enterprise Application Architecture (Addison-Wesley). If thinking on this level appeals to you, architect work may be in your future.

Toolsmithing for Fun and Profit
If you prefer to keep your hands grubby with code, you might consider the job of toolsmith. As far as I know, this position was first described by Harlan Mills (and popularized in Fred Brooks' classic, The Mythical Man-Month). The toolsmith is the programmer who writes tools for the rest of the team. In Brooks' rendition, this was "specialized utilities, catalogued procedures, macro libraries." These days, it's more likely to be XSLT style sheets and code generators, but the job remains largely the same. The goal of the toolsmith is to make everyone else on the team more productive (and, incidentally, to have fun building focused little bits of code that give back immediate gratification).

Two things are key to being a good toolsmith: 1) writing excellent code and 2) having excellent communication skills. Remember, your customers are now right there, in the next cubicle (or office, if you're lucky), and if your tools don't work, you'll know about it very quickly. As for communications, it's not enough to just build tools when someone asks you for something. You need to stay actively involved in the development process so that you can spot opportunities to make life easier for everyone. Finally, you'll need to keep up with that's going on in the development world; sometimes the best tools are the ones that you can download for free, or that are made by other companies. You need to be prepared to help make build-vs.-buy decisions realistically.

How to get started toolsmithing? Build some tools! Spot some part of your current project that can be simplified or automated and then bootleg time or put in your own time to build the necessary tool. Do a good enough job and you'll get noticed. Then you can make your pitch for building tools as a full-time endeavor.

Ringmaster, Anyone?
Sometimes software development seems like a three-ring circus: Over here a handful of developers are pounding out code, in this ring we have testers proving it doesn't work, and way over there are the Web folks trying to deploy the latest semi-stable build. While it may seem like the team lead is in charge of all this, there's another position equally important to coordinating everything: buildmaster.

The job of producing a good build of software varies with the size of the project. If there are only a couple of developers, it might be as simple as getting the latest bits from your source code control system, compiling, and e-mailing the results to your tester. For something like Microsoft Office, it's a complex ballet involving dozens or hundreds of computers, formal procedures, strict timetables, and Web-based status reporting.

Most of us will never build Office, but even a moderate software project has enough steps that it makes sense to automate the build process. Getting bits, setting version numbers, compiling (perhaps several separate versions), posting status messages, rebuilding help files, running unit tests.... As the list of build tasks increases, the chance of missing an essential step increases. And it's well known that frequent builds are the best way to make sure your process is still on track.

Enter the buildmaster and build automation. Whether it's a homegrown set of scripts or a free or commercial tool, there are many choices for automating builds. Perhaps more important is an attitude. The buildmaster needs to think about what can go wrong, and relentlessly eliminate manual steps from the process. They also need the fortitude to confront anyone who breaks the build or won't follow the rules. It's usually pretty obvious when the build process is broken: Testers sit around with nothing to do because working software never lands in their laps. If that's the case in your organization, consider stepping up to offer ideas and solutions. You might find yourself a new sideline.

Beating Software With a Stick
Speaking of testers, just how much do you know about software testing? If you've been listening to me rant lately, you may already be doing unit testing (I hope so!), but there's a lot more to the testing job than that. The quality assurance folks also need to make sure the software can be used by mere mortals, that the tested functions work together in a cohesive whole and that the user interface makes sense, for example.

If you've got some spare cycles, using some of them to find out how the test team works and what sorts of things they do can be an excellent investment. First, you might discover that test appeals to you as much as development, instantly doubling your opportunities—and, in most modern software organizations, writing tests is just as important as writing code.

But there's an even larger benefit lurking here: If you can learn to think like a tester, you can catch more errors before they ever make it off your desk. Good testers can be incredibly inventive about the things that they try. This is good, because real users are the same way. If your software breaks when someone runs it during a full moon while listening to MP3s, then it's broken, whether you considered that scenario or not. A few hours watching a good tester pound on your software can be both an illuminating and a humbling experience. It can also inspire you to brush up your testing skills.

Your Knowledge In a Box
Finally, if you can write words as well as code, you might think about the area sometimes known as UA, for User Assistance. Software is worthless if the intended users can't figure out how to use it. To combat this problem, someone has to write the array of manuals, help files, and Web sites that are designed to teach software operation. To some extent, writing good documentation depends on the same skills as writing good code: You need to grasp what the program is doing and know how to make it do what you want.

But there's a lot more to UA than just copying the comments out of the code. First and foremost, you need to remember that you're explaining the application to its actual users, who are unlikely to be developers. Things that are blindingly obvious to you may require drawn out explanations, and terms you've known for a decade might still need to be defined. You also need to know how to write sentences and paragraphs that actually make sense. Not to put too fine a point on it, that's a tough job for many excellent coders.

Still, if you can manage it, UA skills will open more doors. Writing skills are important in everything from giving conference presentations to coming up with plans for future improvements to your software. And the best way to learn to write is to simply practice. UA work can give you a way to practice in a tightly constrained environment, where you can concentrate on a single task (helping users with software) and learn to do it well.

One Hat or Many?
That's a lot of hats to try to wear, and I didn't even discuss things like graphic design, marketing, and licensing, all of which come into play when you're trying to get software packaged and sold. I just know I'm going to get mail from people arguing that developers should simply concentrate on being better developers, and let the support organization take care of all these other roles.

Here's how I look at it: Being a great developer is a fine thing, but in the current economy, depending on just being a developer makes me personally nervous. This industry has gone through a number of upheavals in the past few decades and I'd hate to lose my career to the next upheaval. Learning extra skills is just like diversifying your stock portfolio—it's an easy form of insurance. To me, at least, it just makes sense to learn new skills, especially if they help make me a better developer themselves.

Want to continue the debate? Got a different career strategy I haven't mentioned? You can get hold of Mike at [email protected]. I'll use the most interesting comments in a future issue of Developer Central.

comments powered by Disqus
Most   Popular