Here are some notes about where I might like to go in considering the New Framework idea. I’ll update this from time to time and maybe bump its date when I do. We’ll see.

Manifesto Principles and Values

This is where it all began, and for me, it all comes back to this. We’ll try to refer to the Manifesto where it’s appropriate, and may write some articles starting from it.

Practices (from XP)

Whole Team

A central idea, beginning with having at least all the developer and testing skills you need inside the team. Includes the Product Owner / Customer notions from Scrum and XP. The ideal, however, is surely a cross-functional, self-organizing Team with full responsibility and authority for building the desired product. Consider a team in a garage, or a Lean Startup.

Planning Game

Two key aspects at least: iteration or Sprint planning, and “release planning”. Is the latter necessary? If so, how should it be done? What responsibility does a self-organizing team have to think long-term, reveal its thoughts, commit to schedule?

Small Releases

This is fundamental! Bring this up to the top in the notion of Increment and make it central. Note that the Manifesto refers to “working software” about 300 times.

Customer Tests

Good idea, too specific?1 Good way to ensure we understand and agree on the meaning of the next story slice. Good way to communicate when Customer is (somewhat) separate from development team. Good way to be sure, every iteration, that the product still works. Not sufficient on its own, or with Programmer Testing, yet often better than many teams have today.

Collective Ownership

See Whole Team. Includes the key notion that “T-Shaped” or “Paint-drip Shaped” people are more valuable than isolated specialists.

Any “pair” can improve any code, any time. See Pair Programming

Coding Standard

Too specific, but a key point: we all try to code alike so that we can all understand everything we have all done.

Sustainable Pace

Many ideas hiding here? Dark Scrum pressure, “twice the work” thinking, concerns about commitment, prediction, estimation.

Fundamental idea is to work at a pace such that real progress is steady and consistent and predictable, and so that people don’t burn out. Consider human values like having a life.

Metaphor

This goes to some idea of common understanding among the Whole Team of how the product works. Not just the code style, or the architecture, but also the overall conceptual coherence of the product idea and design.

Continuous Integration

Too specific. Part of Increment. This is how you get the ability to build an Increment every iteration: if you don’t integrate every day, you’re in for a hellacious Friday and a long weekend of work.

Test-Driven Development

Too specific, yet a key skill to have. Works, when you’re good enough at it, better than anything else, especially in a team situation. Former name Programmer Testing was probably better. Perhaps the fundamental idea is Confidence, an increasing certainty that the product actually works, does what you intended, isn’t regressing, and is heading where you currently think you’d like to go.

Note that Confidence is a good place to put “sapient” testing, user testing, market testing, and the like. (About which I know almost nothing.)

Refactoring

Again too specific, yet absolutely critical. See Nature, need for incremental design implies refactoring implies automated tests.

Simple Design

Possibly Shared Simple Design? One aspect is that we must perforce evolve the design and should therefore start with the simplest design that can work, and must be very skilled at evolving that design, using Refactoring and Programmer Tests, and Customer Tests to have Confidence that everything still works.

Pair Programming

A marvelous and difficult practice. Compare with Mob Programming, which may be less difficult and is certainly in the same idea space as pairing. Helps with Whole Team and Collective Ownership, helps to ensure team resilience under change, and flexibility as priorities shift.

Scrum

We’ll surely be talking about Scrum, and may or may not start articles from a look at Scrum

Scaling

Yes, well, I’m against it. We’ll talk about what I mean by that.

Agile Fluency Model

An interesting model that may get referred to …

Variants

Other “name brand” forms exist. SAFe, which is politically safe at least. Modern Agile, FASTagile, DaD, LeSS, etc etc. We might find it desirable to compare with these but we’re going to try to avoid the Strawman trope.2

Etc

Doubtless there will be other angles showing up as time passes. We’ll see.


  1. I’ll say this often, I bet. I just mean that this is a good idea but feels too detailed to be the top-level practice. We’ll want to find a suitable more general topic or place for a “too specific” idea to live. 

  2. “Idea looking relatively good next to a straw man.” Strawman image