Agile Impressions

Book about Agile Software Development by Jerry Weinberg https://leanpub.com/jerrysblog

Mostly structured as ponderings of each piece of Agile Manifesto, plus a nice history intro (doing Iterative development in the 1960s).

Excerpts

Iterative Development: Some History

We were doing incremental development as early as 1957, in Los Angeles, under the direction of Bernie Dimsdale [at IBM’s Service Bureau Corporation].

When much of the same team was reassembled in Washington, DC in 1958 to develop ProjectMercury

Was There Process Before Agile?

the process models you mention and describe are Waterfall, Cascade, Iterative Enhancement, and Prototyping

Agile is much more than these processes, making explicit many team practices to support the iterative nature of the development

It’s not an Agile process if the customer (or surrogate) isn’t participating

Agile and the Definition of Quality

The reason for my dilemma lies in the relativity of quality

Take for example Crosby’s definition:

“Quality is meeting requirements.”

Unless your requirements come directly from heaven (as some developers seem to think), a more precise statement would be:

“Quality is meeting some person’s requirements.”

quality does not exist in a non-human vacuum, but every statement about quality is a statement about some person(s).

Recognizing the relativity of quality often resolves the semantic dilemma. This is a monumental contribution, but it still does not resolve the political dilemma:

*More quality for one person may mean less quality for another. *

Whose opinion of quality is to count when making decisions?

we see that software engineering is not a democratic business. Nor, unfortunately, is it a rational business, for these decisions about “who counts” are generally made on an emotional basis

Quality is value to some person

By “value,” I mean, “What are people willing to pay (do) to have their requirements met.”

Of course, much of the time these political/emotional decisions–like all important political/emotional decisions–are hidden from public view

  • I don’t consider Agile any team with even one secret component*

As a consultant to supposedly Agile teams, I always examine whether or not they have active participation of a suitable representation of diverse views of their product’s quality

Five Questions on Agile

You may or may not stay out of trouble, but if trouble comes, you’ll see it coming in time to do something about it

challenge is to manage the human reactions to change.

I’ve been trying two new approaches

our Problem Solving Leadership workshop (PSL)

Fiction, or what I call “nerd novels.”

Manifesto for Agile Software Development

Satisfying Customers

*Our highest priority is to satisfy the customer through early and continuous delivery of valuable software. *

I can classify the major violations I see in the following categories

Placating Paradox

Paradoxically, our desire to satisfy our customer has placed us in a situation where we won’t satisfy our customer

Dennis Cadena employed The Rule of Three to come up with three things to look for

Bullying behavior • “Poor me” behavior • Flattery

“Maybe I am placating when I feel that I HAVE TO act in a certain way

For most of us, breaking these placating habits is a lot easier when we’re not face-to-face

Dwayne’s suggestion _(Write on paper what I want to say) worked well for me

The Yes-No Medallion, of course, is not just a No Medallion

Don’t say yes to a client’s first offer, but never say no

Satir’s Soft Spurn is to day something like “Thank you for thinking of us, but your idea doesn’t fit for us at this time.”)

SATISFY WITH SOFTWARE NOT WITH PROMISES OF SOFTWARE

Welcoming Changing Requirements

Welcome changing requirements, even late in development. Agile processes harness change for the customer’s competitive advantage

The engineers need to learn that they will never become an Anticipating organization by getting better and better at coding, even though that was the improvement process that brought them as far as they’ve come.

What Agile methods do not address directly is how those customers can know what their requirements really are. That’s the problem addressed by our books, Exploring Requirements: Quality Before Design

Deliver Working Software Frequently

Deliver working software frequently, from a couple of weeks to a couple of months, with a preference to the shorter timescale

Many organizations fail to realize that this principle implies that software testing be an integral and continuous part of the development process, not something stuck onto a massive code base just before scheduled final delivery

the Edsel Edict:

If you must have something new, don’t have two.

Volkswagen Verity:

Though newness can’t always be refused, it can always be de-fused

Engineering experience has shown that when designers use a prototype, they have a tendency to attempt too great a leap forward. Partly to justify the “extra” expense of the prototype, and partly out of the added confidence that prototyping lends to the project, they heap new features onto the product

Using Agile successfully, we must protect against the WIBINIs.

WIBINIs? What’s that? It’s an acronym for the phrase, “Wouldn’t It Be Nice IF?”.

check that everything in the code relates to a specific part of a specific story for the current iteration

the team’s customer must be made aware of the costs of added niceties

Working Together

Business people and developers must work together daily throughout the project

As a consultant, when I learn that a project lacks daily contact between developers and customers, I can confidently predict failure

On the other hand, close contact between developers and customers can produce an unstable situation where the product definition changes in response to every whispered possibility

Motivated and Trusted individuals

*Build projects around motivated individuals. Give them the environment and support they need, and trust them to get the job done. *

Micromanagement is poison to would-be Agile projects.

if you can’t assemble a team you can trust, then you shouldn’t attempt to make it into an Agile team

If teams are consistently late and/or wrong, managers don’t really care if the developers are liars, incompetents, or simply at odds with the signs of the Zodiac. They learn that they cannot trust the teams, so soon they start taking steps to protect their own jobs.

Only after many rounds of recriminations, evaluations, and firings do managers begin to understand that they’re never going to find developers that can be trusted—mainly because programming is a particularly difficult thing for human beings to do. Then the managers start to implement systems of management—such as technical reviews—that compensate for the weaknesses that all people, even developers, have. (That’s why reviewing is a part of the Agile philosophy in the first place.)

Unfortunately, by this time the developers have plenty of reasons not to trust their managers. In such an environment of distrust, management would be suspected of evil intentions if they passed out envelopes full of cash

*We classify reviews into two main types: formal and informal. The only difference between them is whether or not the results of the reviews are written down and available to managers as an aid to managing. Informal reviews’ output is for the workers only, to help them improve their products. *

As the definition indicates, the word “trust” mixes up several different kinds of trust, including firm reliance on:

• the performance of a thing

• a person’s ability

• a person’s integrity

Properly managed, technical reviews are an effective way to build, or rebuild, trust. Wherever a system of technical reviews has been installed successfully, I seldom find the vicious cycles of mistrust between managers and technical staff members, or even between staff members, such as, programmers and testers

Face-to-Face Conversation

The most efficient and effective method of conveying information to and within a development team is face-to-face conversation

common prejudice against written communication. I see many would-be Agile teams who use this principle as an excuse for not writing anything, even when detailed written specs are the only reliable way to communicate such technical details as the exact interface between two systems.

In many IT installations today, the number one problem is program maintenance

face-to-face communication fails as a maintenance tool if the development team is no longer around. Many people have complained about this maintenance deficiency of the Agile approach, arguing that massive documents are necessary to overcome it.

the first tactic to lessen the difficulty of maintenance is this: keep teams together

Another maintenance tactic is the disposable program

But why not just keep all programs, for all time? That would be an excellent, simple solution, except for one thing: cost. A program brought out of hibernation can incur numerous costs

why, do we keep tumbling into the same trap?

the answer to the “why” question lies in our unwillingness or inability to feed-back the true costs of programming and program maintenance to our customers

service bureau clients

In internal data processing situations, especially where there is no true chargeback for programming or program maintenance, these lessons are difficult to teach

these two tactics will not eliminate all maintenance problems. If you want continuing success with Agile, you’d better face the remaining problems squarely

Except for truly disposable programs, any real system must be maintainable. Thus, maintainability is the job of the Agile team, just like any other non-functional requirement—efficiency, portability, security, and so forth. But maintainability is not something simply contained in the code. It’s a relationship involving the code, the documentation, and the environment in which the maintenance will be done

they will argue that the code says everything the maintainers need to know—but that’s a fallacious argument.

The code only tells what it does, not why it does what it does.

The conceptual problem IT managers have with this type of worker stems from their confusion between documentation and documents

There may be lots of other paper documents lying about, but what they’re lying about most of the time is the code

When a question arises that can’t be answered directly out of the maintenance programmer’s own head, the first source of information is old George who worked on this system a couple of years ago

assist the natural processes of documentation in doing programmers’ job—before trying to introduce artificial methods. For instance, since the code is the basic ground upon which all documentation is based, why not take steps to improve the quality of code as documentation?

The first step in such a code improvement program is to be sure that no code goes into the code database without having been read and understood by one or more people

improve the quality of individuals as documents. As a first step in this process, you should notice that when individuals leaves an organization, they lose most of their usefulness as documentation. Therefore, any policies that reduce employee turnover are likely to improve the quality of the living documentation

Why not have the designers on each part of the system take a few minutes to record the thought process that went into the design—the story that will be lost to view after a few months

each piece of code should contain a prologue cumulatively listing all the people who ever laid a hand on the code

meta-data for each line of code containing the name of the last person or team who submitted it

Even your regular paper documents should contain an adaptive index to the people who worked on or used them

identity of each person who read the document and at least partially understood it

Working Software is Primary

Working software is the primary measure of progress

Working software is indeed the primary measure of progress, but it’s not the only measure

Sustainable Development

Agile processes promote sustainable development. The sponsors, developers, and users should be able to maintain a constant pace indefinitely

After becoming winners, our five heroes each worked at a non-sustainable pace, largely due to the Pile-On Dynamic

When they’re overloaded, they tend to ignore any task that doesn’t contribute instantly to the primary task.

In other words, they can no longer pay continuous attention to what made them best-infomed in the first place

Technical Excellence

Continuous attention to technical excellence and good design enhances agility

Technical excellence comes not from heroics, but from continuous growth as a technical leader

what makes a team member grow into a team leader

Early Training

Although good technical people are rare, their growth is at least more predictable than people who are good at working with others. That is, the spark of technical talent shows up early, and we know quite a bit about how to fan it into flame.

If a person lacks knowledge of the inner workings of a complex system, we can provide it through role assignments

Ability to work with diverse teammates is a learned skill

programmers are thrown onto “teams” with essentially no training in “people skills,” although their are many available mechanisms for improving those skills

the chief programmer approach .(see, for example, http://itinfralogistics

Because the entire success of the CPT revolves around the CP’s capabilities, the success of early CPTs actually depended mostly on who happened to be around to be chosen CP

Catching a moose is one problem, but maintaining it in the style to which it is accustomed is perhaps a problem of a higher order

Starting a Successful Team

how many people in the world meet your qualifications to be a chief programmer?” I asked.

Harlan held up both hands with his fingers spread. “Ten thousand?” I asked.

“No,” he said. “Ten

Maintaining a System of Teams

to maintain a CPT system, you need more than an initial supply of CPs. You need replacements

The principle of technical excellence means that not just anyone can qualify as an Agile team member

Congruent Interviewing by Audition

But the really interesting one-third took offense at the question and walked out of the interview. In fact, the question could be used partly for that specific purpose: as a simple way to exclude those who too readily take offense

Another mistake would be to ask for more than a ten-minute audition

It would also be a mistake if the candidate were given a deep design question and asked to give an answer in twenty-five words or less, in one minute or less

Simplicity

Simplicity—the art of maximizing the amount of work not done—is essential

We don’t really have a measure of simplicity of work. What I do have is a measure of bureaucracy:

The amount of work we do for which we cannot explain its purpose

Self Organizing Teams

The best architectures, requirements, and designs emerge from self-organizing teams

Yes, furniture arrangement is one aspect of self-organization, but more important aspects include the team’s working process, the role of each individual, and the acceptance and rejection of assignments.

Moreover, a self-organizing team is not permanently organized, but adaptive

Just leave them alone, and they will organize themselves.

WRONG!

The manager’s job with respect to an Agile team is to start it when a team is needed, leave it alone when it’s working effectively, and stop it when it’s not

To say more, many books have been published, including my book, Managing Teams Congruently (Volume 6 of my Quality Software Series

In a Self Organizing team, every member sometimes acts as a leader

PSL Workshop participants learn a number of skills critical to self-organizing team members, such as, how to:

when I’m confronted with a non-working team, I check a list of vital ingredients teams need. Nowhere on my list do I have the word “Leader.”

  • a team is a system. Like any system, it won’t generally be understood by slicing it into little pieces*

We all do that sort of selective remembering when the facts don’t fit our favorite hypotheses. And what is the number one all-time favorite hypothesis of any manager?

“The appointed leader is the sacred spark.”

why is the appointed leader the one who’s most likely to break down?

Answer: because people believe in the Myth of the Appointed Leader.

  • “Which would you rather have? A team that never fails, but you don’t know who’s responsible for their success? Or a team that fails regularly, but you know exactly whom to blame?*

A team with an appointed leader can be self-organizing if that leader is wise enough to lead by consensus.

Reflect and Adjust

At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly

Rhonda’s First Revelation [see, The Secrets of Consulting] says:

It may look like a crisis, but it’s only the end of an illusion.

In other words, Agile practice of reflecting at regular intervals is a way of exposing illusions before they become crises

Remember our heroes from an earlier chapter, Frank, Iris, Barry, Ahmed, and Sue Anne? What could these heroes have done to maintain their effectiveness?

Over the years, I’ve observed two major mistakes by Agile customer surrogates. First, and most frequent, because they’re well-rooted with their customers, they fail to spend adequate time with their Agile team. Second, perhaps to prevent that first problem, they fail to spend adequate time with the customers they’re supposed to represent, so they become out of touch with their true needs

the most powerful time to think of such job alternatives is when the manager needs something from you, not after you’ve already mindlessly accepted the ill-considered job

An Overriding Principle

Be reasonable

To make sense, each of the Agile principles must be applied with the mind fully engaged. That’s true of any derived principles, too.

Why People Don’t Instantly Buy Into Agile

evangelists often stress the strength of Agile methods at removing, and even preventing, errors. I used to stress this advantage myself, but I always wondered how people could resist this sales pitch.

If they payoff is so huge, why aren’t we raising software quality to new levels? We could ask the same question about improving auto safety

They’re so common that we’ve learned to take them with an accepting shrug

each new feature, no matter how potentially valuable, has a downside–a negative quality value because of its unfamiliarity

It’s a classic catch-22. To convince people of the value of Agile, we need to produce software that is full of wonderful features that the old software didn’t possess, at the same time the new software functions exactly the way the old software did. No wonder change is difficult

Beyond Agile Programming

whole section entitled, “Beyond Structured Programming.” As I contemplated updating that section, it dawned on me that I could almost update completely by substituting the name of any more recent “movement” (or fad) for the word “structured.

*I also knew how smart most of my readers are, so I figured they would see the same possibility without my updating a thing. Instead of changing the book, I decided to update the section and publish it on this blog. *

First Conclusion

Much less has been done than the press would have you believe

Second Conclusion

There are rather many conceptions of what agile programming ought to look like, all of which are reasonably equivalent if followed consistently

Third Conclusion

Methods representing thoughtful adaptations of “patented” and “local” ideas on agile programming are far more likely to be followed consistently

Fourth Conclusion

now I must pause and relate the effect these observations have on many readers, perhaps including you

“These can’t be right, because if they were right, why would there be so much attention to agile programming?”

The answer can serve as my fourth observation:

*Agile programming has received so much attention for the following reasons: *

So actually, the whole agile programming pitch was pre-adapted for the ease of professionals, who have always believed “problems” had “solutions” which could be mechanically applied

The Final Conclusion

Those installations and individuals who have successfully realized the promised benefits of agile programming tend to be the ones who don’t buy the typical hardware or software pitch, but who listen to the pitch and extract what they decide they need for solving their problems. They do their own thinking, which includes using the thoughts of others, if they’re applicable. By and large, they were the most successful problem solvers before agile programming, and are now even more successful

Our profession contains few, if any, easy solutions


Edited: |

blog comments powered by Disqus