Continuous Delivery and Apple
Join the DZone community and get the full member experience.
Join For FreeThe case of Apple sometimes comes up in discussions around continuous delivery and the lean startup. For example, Richard Durnall described Apple’s strategy to me on Twitter as follows:
Brilliant and unwavering product vision from a few amazing folks going to market infrequently with huge ceremony.
That seems to be the exact opposite of what both lean startup and
continuous delivery preach. It’s hard to know what happens behind the
scenes at Apple because of their notorious secrecy about their product
development process. Furthermore, there’s no way of knowing if the
information we do have accurately represents what really goes on there.
But if we look at Apple’s history, there are a couple of examples that
strongly suggest that the principles behind continuous delivery and the
lean startup were very much in play in Apple’s early years.
Exhibit A is the Apple I. Created in Steve Wozniak’s parents’ garage, and sold without a keyboard, display, power transformers or even a case, it is – as Eric Ries has pointed out – a great example of a minimum viable product.
Exhibit B is “The Macintosh Spirit”, an entry from folklore.org – the excellent compilation of stories from the creation of the original Macintosh, submitted by members of the team that built it.
This entry – which describes “The attitudes and values of the team forged the spirit of the Macintosh” – is short and worth reading in full (as is the whole site if you have the time – it’s available in book form too). Here’s a paragraph describing the Macintosh team’s product development process (my italics):
Other groups at Apple had an elaborate formal product development process, mandating lengthy product requirement documents and engineering specifications before implementation commenced. In contrast, the Mac team favored a more creative, flexible, incremental approach of successively refining prototypes. Burrell Smith developed a unique hardware design style based on programmable array logic chips (PAL chips), which enabled him to make changes much faster than traditional techniques allowed, almost with the fluidity of software. Instead of arguing about new software ideas, we actually tried them out by writing quick prototypes, keeping the ideas that worked best and discarding the others (see Busy Being Born). We always had something running that represented our best thinking at the time.
Given that we’re talking about events that were happening 20 years
ago, it’s hard to improve on this as a description of how to do
continuous delivery on an embedded system1.
This example also resolves a common misconception — just because you’re
“going to market infrequently with huge ceremony” doesn’t mean you
can’t do continuous delivery (which is why I am careful to distinguish continuous delivery and continuous deployment, and also to differentiate between the terms “deployment” and “release”).
Rather, continuous delivery is one of the things that enables
successful “high ceremony” launches: if you’re doing it right, the
high-risk technical work happens long before the product launch, which
becomes purely a marketing event – in the case of the Macintosh, one of the most spectacular in advertising history.
1 For a more up-to-date example, check out how the HP LaserJet firmware team moved to a continuous delivery model, including checking in to trunk to do continuous integration, and performing automated functional testing using real logic boards to test the processing algorithms and timing.
And be sure to check out the Continuous Delivery presentation series going on now.
Published at DZone with permission of Jez Humble. See the original article here.
Opinions expressed by DZone contributors are their own.
Comments