Posted by Dave West on August 30, 2011
How many times have you heard the following phrases?
- “This software bites.”
- “Why is software development always delayed?”
Both sentiments describe the need to design and build software that provides a great user experience (UX) and that is delivered in a timely manner. Luckily, there are two communities focused on both of these goals:
- The user experience gang focuses on designing software the users find useful, usable, and desirable.
- The Agile camp focuses on delivering working software to expose functionality that users can test.
Get These Two Communities Together, And Bam!
But sometimes the “bam” might be for the wrong reasons; UX purists want to spend days upfront planning story boards, task models, and experience metaphors, whereas the Agile camp wants to spend little time planning, preferring the practice of delivering working software to expose functionality that the customer can test.
Neither is right or wrong. Like so many situations, balance should be the objective. You should never spend too long upfront planning the perfect user experience that will be out of date before going live, and you should never start developing software before you have some understanding of how that software is going to be used. Mike Gualtieri and I believe that the following techniques can help application delivery professionals find the perfect balance to achieve that outward Zen:
- Identify personas – As a software engineer, I often forget that I am creating a product for someone else and build products for myself. Avoid this by having a clearly defined yet simple set of personas to remind development team members that they are creating software for someone else.
- Understand the customer’s mission – Sometimes we get so focused on the details of a piece of functionality that we forgot why the customer is using this in the first place. By identifying the objective that you are building software to satisfy, you equip the development team with a clear measure of success – and on Agile projects, the ability to ask “Are we done yet?”
- Define some very simple design guidelines – You are not going to build the plans for the new world trade center, but by focusing on some very simple principles, the development team can build software that is consistent.
- Create tests earlier rather than later – Agile is all about testing your assumptions quickly, learning, and adapting. To do that requires you to have knowledge of what you are trying to achieve and then deliver software to prove or disprove it. Usability, like functional requirements, should be tested as early as possible.
- Deliver frequently, and test your design assumptions – It is clear that the proof of the pudding is in the eating. If the software delivery team frequently delivers software that proves the usability and design of the software, the team and the customer can learn.
- UX professionals should mentor Agile teams – UX, like so many skills, is not one you can learn from a book. By getting involved in Agile projects, UX professionals not only see their ideas get delivered faster but also get to help shape the team’s thinking and approach.
Mike Gualtieri and I will discuss this very interesting topic at the App Dev Forum in Boston on September 22-23.
Search Forrester's Blogs
Free On-Demand and Live Events
Latest events from Forrester analysts, online and in person »
Free Upcoming Webinar
Avoiding The Top Three Customer Experience Risks »
- Anjali Yakkundi (23)
- Boris Evelson (135)
- Claire Schooley (2)
- Clay Richardson (1)
- Diego Lo Giudice (14)
- Gene Cao (1)
- George Lawrie (17)
- Holger Kisker (38)
- Ian Jacobs (1)
- James Staten (7)
- Jeffrey Hammond (26)
- John R. Rymer (45)
- Jost Hoppermann (32)
- Kate Leggett (112)
- Kurt Bittner (3)
- Kyle McNabb (12)
- Manish Bahl (2)
- Margo Visitacion (9)
- Mark Grannan (7)
- Martha Bennett (11)
- Michael Barnes (21)
- Michael Facemire (13)
- Mike Gualtieri (112)
- Noel Yuhanna (10)
- Paul Hamerman (2)
- Phil Murphy (22)
- Randy Heffner (15)
- Stephen Powers (20)
- Ted Schadler (1)