MarkStringer.github.io

The WIFS Syndrome or Why Developing Software Around Third Party Applications is Different

Most of the projects that I seem to get involved with these days involve third party software. The idea is that the bulk of the functionality will be delivered by this third party software. For me this is a total game-changer when it comes to software development - but I haven’t really seen anybody writing about it - especially in the Agile community.

The first problem is choosing the third party application (TPA?). How do you decide which one to use? I’ve tried to assess Kanban-style project management systems and it’s a very difficult and painful process. One company that I was doing some work for recently was going spare because they had the contract to maintain all the IT for another company. The client company was a partnership, so if one of the partners asked to have some software installed on their computer, they couldn’t really refuse. But at the same time, they had no idea what that particular piece of software might do, how it would interact with other pieces of software.

There are some other weird things that happen as a result of this shift towards using TPAs.

Animals are usually unable to escape from the asphalt when they fall in, making these pits excellent locations to excavate bones of prehistoric animals. The tar pits can trap animals because the asphalt that seeps up from underground forms a bitumen pit so thick that even mammoths find it impossible to free themselves before they die of starvation, exhaustion from trying to escape or from the heat that would come from the sun. Over one million fossils have been found in tar pits around the globe.

I want to be able to write letters with this software - can it do that straight out of the box?

The developers scratch their head and say

No, we don’t think it can.

Now the Product Owner comes up with the fateful question:

But could it do this, if you customised it a bit?

And of course, because software is tractable. The answer is always:

Yes.

Mid-Project Review Meeting

“This Mid-Project Review Meeting isn’t Going as Well as Expected”

The developers start to get excited about how they could use the crop-spraying simulation and put weed-killer in the tanks of the crop-sprayer and therefore make brown marks on yellow cornfields and then by simply switching to the space-shuttle simulator we can view these cornfields from space as letters (yes, I know, something like this actually happened with PostScript - which started off as a way of capturing three-dimensional objects, like ships and buildings around New York Harbour - do we really want to go through that again?). This project is already starting to look expensive, error-prone and disastrously difficult to maintain (how is this stuff going to work with the next update to Flight Simulator? Thought so). This project is looking pretty bad, especially compared to good old Microsoft Word which can actually write letters out of the box! I’ve worked on a project like this.

What needs to happen to stop this?

Testers, analysts, developers and product owners need to pick some minimum viable product requirements, and ideally pick the TPA based on those. In order to do that, they probably need to implement some stories in several TPAs. The selection of these stories should help coalesce the idea of what the minimum viable product is. But the stories should also test what it’s like to customise the TPA and push it a bit beyond its boundaries.

OK - let’s try this. What’s the customer’s archetypal story?

Story 1: As a nephew I want to write a letter so that I can thank my great aunt for the lovely jumper she knitted me

And what’s the outlier customisable story?

Story 2: As a nephew I want to print out this letter to my Aunt so that it looks like it was done in mediaeval script on parchment

And how do these stories pan out in the two different applications that we’ve mentioned.

In Word: Story 1 takes 1 hour (I know the devs said it would take “2 seconds”, but what can you do?)

In Flight Simulator: it’s estimated to take 1-3 years and 3-10 million pounds (so probably about 30 million).

How about Story 2?

In Word: The devs said a couple of days - it took a couple of weeks, but there are still a few problems.

In Flight Simulator: 6 months to a year (so probably another 30 million pounds).

The punctuation Bomber

“We’re planning on using this for the full stops”

Some other things that I’m realising about this process as I’m writing.