Disclaimer: I wrote the book "Essential Copying and Pasting From Stack Overflow" , which was inspired by a cover designed by ThePracticalDev . This blog post is also inspired by a cover designed by ThePracticalDev. Just like "Essential Copying and Pasting From Stack Overflow", "Expert Resumé Driven Development" is also written in a deadpan manner.
What is "Resumé Driven Development"?
There is some controversy on whether Resumé Driven Development is actually good. Paul E. Davis defended the practice as it is an indictator that the developer is willing to learn new technologes instead of sticking with potentially obsolete solutions. Sure, "Plop.js" may not actually be suited for your use case, but at least you showed that you can learn it and use it quickly, and that you could later on find the bleeding-edge technology that might actually be useful.
"In the end, if developers are not concerned with their own careers, it’s not likely they’ll be concered with your business."—Paul E. Davis
Most developers seem to detest RDD though (as can be seen by this parody website ). There is a general belief that developers are not using using the hot new technologies in their spare time, but instead using them on company projects . This is a colossal waste of company funds, as the technology may be ill-suited for the task at hand and can lead to long-term maintanance headaches.
Developers are not the only people that engage in Resumé Driven Development. Management may also engage in RDD during the hiring process as well . If a job vacancy exists, there is a desire to hire a new programmer with the same skillset of the old programmer. So the old programmer was an expert in Plop.js, then the job posting will read "6 months experience with Plop.js". This may be a very bad thing because you are optimizing for knowledge of certain technologies, instead of choosing the "right tool" for the job. If you only hire Plop.js developers, you will only get Plop.js websites.
RDD is probably a subset of a larger Principal-Agent Problem . The Principal (management) hires an Agent (a developer) to build a program and allow the Agent to choose the tech stack. But the Agent’s interest (making his resumé more impressive) can be orthogonal to the Principal’s interest (producing a great product by using the "right tool" for the job). If the Principal allows the Agent to do as he wish, then the Agent will do as he wishes, thereby leading to the Agent to prosper and the Principal to suffer.
RDD is composed of two sections: the Resumé and the Technology. Let’s look at them both briefly.
The Role of the "Resumé"
A resumé serves to let people know what you have done, in the hopes of getting people impressed. According to a study by TheLadders, a resume re-writing company , recruiters can spend 6 seconds per resumé, scanning for keywords and cursory background information about your education and job history before deciding whether you are "fit" or "no-fit". You can see why some developers want to maximize those 6 seconds by practicing RDD.
Now, there is not that much in-depth examination of what’s on the resumé. If someone says that they used Plop.js when building a Uber-For-Dogs application, then you assume that they did use Plop.js and that there actually is a Uber-For-Dogs application…that he really spent 6 months on it…and that he got to pet a unicorn while on the job. It says so on the resumé. Just keep scanning for more keywords then.
You can see where I’m going here. Resumés can lie. You can claim to have worked on sixty Plop.js projects in closed-source companies, and provide fake phone numbers and references as ‘proof’ that these closed-source projects exist. Lying is horribly unethical, and I would not recommend it for anyone to do. But it can be done, and is probably more efficent than a pure RDD approach…at least in getting the foot in the door. However, at the interview stage, interviewers will attempt to weed out those that did lie on their resumés – such as asking basic questions like "What is Plop.js?".
So the better option is to actually use the technologies on real projects then, so that when you get to the interview stage, you can actually prove your expertise in it and not be exposed as a fraud. That (sadly) means you do have to build a Uber-For-Dogs application just so you can use the Plop.js keyword. You may even need to provide a link to the application and show the source code, in case someone looks at your resumé for longer than six seconds. However, once you do this, you do not have to worry about proving anything else. If you can demonstrate that you can use Plop.js, then most people will assume that you know how to use it.
Choosing the Hot Technology
The biggest problem with choosing hot new technologies isn’t actually learning them. It’s difficult, and you’ll have to deal with bad documentation and difficult solutions, but given enough time and persistence, you will eventually succeed.
No, the biggest problem with choosing hot new technologies is that you don’t know what is actually hot.
You can guess. You can listen to a community, and if the community talks a lot about Plop.js, then that suggest that Plop.js is hot. If the community stops talking about Plop.js, then Plop.js must not be hot. You can bookmark Google Trends and pay attention to what words people are searching. You can look at job postings and see what keywords the recruiters are using. And so on and so forth.
But they’re all trailing indictators. It doesn’t help you predict whether that tech will stay hot in the future.
It is here that Gartner Hype Cycle can be most useful for an RDDer. Gartner argues that all new technologies go through a cycle. I described the Hype Cycle in my blog post against Artifical Intelligence …and I reprint my comments on this cycle here:
At first, people become very interested in a brand new technology (a "Technology Trigger"). Companies start to over-invest in researching this technology, leading to a "Peak of Inflated Expectations" (i.e, a bubble). But the technology turns out to have major limitations. As a result, investment in the technology dries up ("Trough of Disillusionment"). Most companies either begin laying people off or closing down outright.
Eventually, the survivors soon realize how to use the technology properly ("Slope of Enlightenment"), and we can finally use the technology in our day-to-day life ("Plateau of Productivity"). But as this picture from Wikipedia shows, the visibility of the technology in the Plateau of Productivity is much less than the visibility of that same technology in the Peak of Inflated Expectations. The brand new technology has done great things for us. It’s just not as great as we hoped it to be. And does it justify the extreme waste seen in the "Peak of Inflated Expectations"?
Since the technology reaches the maximum visibility/hype in the Peak of Inflated Expectations, this implies that, by the time you hear of a tech, it’s already too late . The only people who would be able to take advantage of the hype are the ‘early adopters’, and they are the ones who will likely reap most of the benefits (though they also accept most of the costs as well, since not all new technologies are interesting or useful enough to go through this Hype Cycle).
Another message this chart tells us is that the best time to learn a new technology is either during the Technology Trigger or the Trough of Disillusionment.
During the Technology Trigger stage, there are no experts. There are only a few people who know your keyword. Specializing now as an ‘early adopter’ (while the field is still young) would be much more impressive than being an expert during the Peak of Expectation, when you have thousands of ‘experts’ in your field. Building a bot that can draw paintings now seems neat. Building a paint-bot five years from now, when every programmer have already built their own personal paint-bot? Boring.
During the Trough of Disillusionment, you are able to take advantage of previous research done during the Technology Trigger and the Peak of Inflated Expectations, learning from past successes and failures with the tech. You also will have less competition during the Trough, as most programmers have already left to move onto the next "hot" technology. Eventually, interest in the tech will revive, and your lovely keyword will regain some allure.
Any other time to study a technology would carry either too much competition (the Peak of Inflated Expectations) or too little reward (the Plateau of Productivity) to justify the expense. The only reason you would want to study the technology in that case is because you think it might actually help you grow as a developer.