I spend most of my waking day on a computer, using software. Then I get on twitter and share all the many ways that software annoys me, frustrates me, or just plain pisses me off.
Because most software sucks.
Most software seems to have lost sight of what it is trying to achieve or has chosen mediocrity in order to kick something out the door and label the work “done”. Unfortunately this is the kind of “done” that ends in contract and scope arguments, with overtime paid to the developers and a customer unable to do critical parts of their business. That kind of “done”.
The purpose of software is to do work for systems or people.
Do Work for People
Software that is built for people needs to work for people. Far to often software is built with a focus on a dry technical spec or imagined user, but the real user one day putting hands on the software and using it is left completely out of the equation. Rather than treating it as a future extension of the users hand, we get all the functionality in and then attempt to bend the user to fit the software through training or attempting to add usability as magic icing after the software is done.
It shouldn’t be surprising that when you build a piece of software that is technically marvelous and considers the user only as an afterthought, someone like me will get on twitter and tell you your product sucks to use. No matter how wondrous it is behind the scenes, if I can’t understand the instructions, if it requires weeks of training with every release, if I am the least bit nervous about which button to chose to save my work, then your software does not work for me.
The purpose of software is to do work for systems and people. If I can’t figure out how to make it do work, it sucks, regardless of the internals.
Do Work for Systems
We’re living in an age of APIs and SDKs. It’s the world envisioned by the early adopters of SOAP 15 years ago, when every company or service would have external APIs we could consume. It’s a world that started when the first programmer sat down to write a program that interacted with another program. A lot of this world sucks too.
You might be surprised to learn that the intended end user of an API or SDK is not the system. It’s a developer. And just like the previous case, the API or SDK should be designed to help the developer get work done. Except that, once again, the technical implementation often ends up being the focus, with the external interfaces just being nailed on any old way.
The Microsoft SDK has clumsier interfaces, requires a second set of instructions, requires extra abstraction work to allow me to write unit tests for my own code, ... it's the generic MP3 player before iPods ate their cake.
Systems software is typically considered to be easier and free of all that people stuff. Except it really isn’t, it just has a different set of users. The ability for systems software to do work is still very much reliant on the ability for developers to use that bit of software from their future bit of software.
Do Work
But at least we have the technical, people-free portion of the work handled, right?
That depends on your definition of actually “working”, which has two key issues: honesty and understanding.
Understanding the Work
Too many companies draw up a scope of exactly what the customer says they need, then methodically try to deliver exactly that scope. Some waterfall, some iterate, and at the end of the contract they beat their customers into submission with that scope. Because that’s the easy way to do it.
Relations were strained, the customer had gone out on a limb for this project and we kept delivering badly interpreted versions of what he was asking for after not showing him anything for months at a time but an envelope with a bill in it.
The software sucked. And not just because of all the quality problems, performance problems, build problems, integration problems, usability problems, and things we created that they never asked for. It sucked because it was so focused on solving an abstracted, prototyped, guestimated version of the customers process that it totally overlooked the work that needed to be done as well as the genuine pain points that we could have focused on in far less time for far greater effect.
It didn't work and it didn't solve the right problems.
The purpose of software is to do work, if it does the wrong work, then no matter how technically sound or brilliant, it sucks. And if you missed the purpose, you probably didn’t make it very easy to use either, so good luck with that.
Honest Work
Down to the wire, the software has to be delivered next month, and there’s still 3 outstanding features and a slew of bugs. We’ll just ship what we have and if they have any problems with it we’ll have the lawyers point out that we technically delivered what the spec said we would. Point out where it says we can’t charge you to fix the bugs preventing it from running.
What crap.
We are delivering tools to do a job, if it doesn’t work then it doesn’t work. Delivering it that way and hoping that the customer won’t notice? Fraud.
I’m not saying every piece of software has to be delivered bug free, what I’m saying is to be honest about your work. And in the case above, honesty means owning up to the customer that you will not be able to deliver what you promised and now have to chose between fixing these 3 broken features or adding 3 more. Which is painful, I’ve had to have that conversation before, but lying by delivering a mass of unworking software is for charlatans, not professionals.
The purpose of software is to do work, if it doesn’t function then it doesn’t do the work.
It’s About People
At the end of the day, software is about people and too much software forgets that. Even the code we write should be written for future developers to read and improve upon, covered in unit tests to provide a safety net for future development, revised and improved upon as we gain a better understanding of the goals of the work the user wants to do or as we find better ways for them to interact with the software. And I haven’t even mentioned all the non-code aspects of good software, like the importance of good support and communications.
The purpose of software is to do work for systems and people. For people and by people. Miss that and random tweets are the least of your worries, it won’t take the next iPod to eat your lunch, just a mediocre application that gets some of that equation right.