Requirements Versus Partnership

Requirements Versus Partnership

One recurring theme in software development is 'requirements'. This seems to be one of the most challenging starting points of any software development project. My experience is that the crucial point is 'explaining what you have in mind, what you want to achieve'. Now I see the following problems with labelling the challenge in outsourcing as 'making requirements':

a. It implies that making requirements is largely a role of the outsourcer.

Outsourcers oftentimes do see this as their responsibility. I would argue that this assumption is flawed. During the weekend, I placed a job on a 'handyman' website. I want to re-paint my wooden floor. I had problems with the floor, having to paint it each 2 months. I could explain my problem very clearly. As a reply, I got few questions and some proposals. With one round of answers, the handyman can make an offer for the job.

But in software development this doesn't work. It is hard to picture what you need and ideas change during the development process. The team that builds the software needs to be engaged in determining what needs to be built.

b. It's based on the waterfall model

We used to build software step by step, first spending weeks specifying everything, then building and testing it. We found that scrum and agile work better. In scrum you don't need to have big requirements, you can enter the process with a vague idea. The team then comes up with user stories that are converted into working software. Requirements are made by the group during the whole process, not upfront.

c. It reduces the challenge to 'requirements', which isn't the whole story

Software development is a creative team effort. Great software is a product of the people you have on the team, the roles they have and the process they follow to produce the software. Good requirements follow if people, roles and process work synergetically. It's not one person sitting in a room thinking about what to build and putting that in a document.

The challenge in software development is not 'making requirements' in isolation. It is getting the whole process right. This starts with getting the right team that knows how to build what you want to be built. It requires a team that views building software as a partnership. When you send these great requirements you made up in your company to a team and ask them to estimate this, you get what you asked for. But the team probably won't go the extra mile.

When you make an effort to make them a true partner, the team will be vested in the outcome. This doesn't need to be an economic partnership, it can be an emotional partnership. The handyman who fixes my floor takes pride in the end result. He does his job because he loves the smile on my face when he does the job well. So does a software team. Effective teams want to put their ideas into your software, they take pride in co-creating it. But if all is already nailed in solid requirements, there is no space for that and they'll just build what you ordered.

This implies that it's often better not to make requirements at all. Instead, find a team with experience in what you want to build, which understands your business and which goes for true partnerships. And then engage them in ideation from the beginning, so they get an emotional bond with your software.

Source: Bridge Blog

Oliver Meili

Connecting People, Things and the Dots

9 年

I see a few factors influencing what would be the optimal thing to do: 1) How well can you/do you want to describe your needs? You might have constraints that need to be met by the software, so you do need written requirements/user stories for those, no matter what the development process. 2) Linked to 1) How well is your development team able to propose requirements or user stories on their own? How well are they working with their customer to develop the requirements? Some teams are happy with just implementing whatever is specified... 3) Money. If you do not have a clear idea of what you need and you can afford to iterate a few times, it's going to cost. In agile methodologies, an initial product backlog is an integral part of the process. An excuse with agile I hear often is that there is no need for requirements, one can just start coding. I am afraid, but that's nothing more than an illusion. Of course the ideas of working closely with the development (or the customer) and building a good relationship is the best thing that can happen to create great products.

回复

The author writes: "The team that builds the software needs to be engaged in determining what needs to be built." A good requirements engineer will know this implicitly. The "partnership" comes in the requirements analysis phase: determining what is, or is not, feasible.

回复

要查看或添加评论,请登录

社区洞察

其他会员也浏览了