DevOps Blog

What Is Extreme Programming (XP)?

3 minute read
Jonathan Johnson

Extreme Programming is an application of the Agile software development framework. Its goal is to make better software and improve the quality of life for the team members.

How does extreme programming work?

Extreme programming (XP) is an adaptive programming style designed to listen to feedback from both the customer and engineers to deliver a good, and possible, product on time. It is adaptive in the agile methodology in that it is responsive to:

  • Customer demand
  • The possibilities available to your company and your industry

XP is not meant to be used in all software development projects. A particular distinction is that XP is a development framework for fixed-time projects. This is very different from something like Continuous Integration and Development (CI/CD).

Some industries have a pulse to them. Apple puts out a new phone every year, a publisher may push a book every couple months, a software team may release a new version of their software once a year. Extreme Programming has proven beneficial in these environments where you have to meet regular deadlines.

XP team size

Extreme programming consists of small teams of 2 to 12 people. It is possible for an XP team’s size to grow, but the root purpose—adaptability—must still be possible.

Sometimes, more team members come at the cost of adaptability.

XP team roles

It is common to see XP teams include many different roles, not only developers. Like other agile frameworks, an XP team will consist of:

In XP, you can also have two new roles: The Tracker and the Coach.

  • The Tracker. A role a developer generally fills to track particular key metrics of the team’s performance, such as software quality. The role is not necessary. You’ll create it on a need-only basis.
  • The Coach. An outside party who can watch and monitor the team’s performance; this person is often a consultant or a mentor.

(Learn more about Agile team roles.)

XP practices

Extreme Programming is all about communication, simplicity, feedback, courage, and respect. Common XP Practices are:

Get started with extreme programming

First, you need to determine if this methodology is right for you. XP won’t work:

  1. If the project is concurrent middleware development. Too many usage scenarios doesn’t work with XP, and reliable unit testing is impossible.
  2. If the project is OS Kernel and device drivers.
  3. If change is too costly or if you must closely monitor change to preserve safety.

For more specifics, refer to this article.

Second, start a new project. Projects begin with the user. What are their stories? What are their use cases? What is the solution?

  • Develop the communication lines early. If it’s done late in the project, what’s the purpose of doing this methodology in the first place? Rule number one is to communicate so the team can adapt. Start clear communication early. Make it a standard for any project at the outset.
  • Pay attention to the progress of code development. You can paint broad strokes first to get a picture of the finished idea without coding, and then fill in the details later. (Abide by the law of diminishing returns.)
  • Test your application regularly with the user. You do not want to stray too far from the use case. If you do, see if it can be changed to align more with the user’s vision, and don’t be afraid to scrap and start anew. The purpose of agile development is to avoid spending a lot of resources to, in the end, find you need to fit a square peg into a round hole. In agile development, it should be known well-ahead of time the whole is round, and to develop the peg accordingly.

Once these items are in place, XP programming should not feel like a system to strive to achieve, but a natural working order that keeps everyone on track, focused, and relaxed.

The regularity of the product release cycle inherent with Extreme Programming can increase everyone’s sense of time, allowing the excitement to begin when a new project starts, and the happiness, and relief, to follow when a project comes to its deadline.

Related reading

These postings are my own and do not necessarily represent BMC's position, strategies, or opinion.

See an error or have a suggestion? Please let us know by emailing blogs@bmc.com.

Business, Faster than Humanly Possible

BMC empowers 86% of the Forbes Global 50 to accelerate business value faster than humanly possible. Our industry-leading portfolio unlocks human and machine potential to drive business growth, innovation, and sustainable success. BMC does this in a simple and optimized way by connecting people, systems, and data that power the world’s largest organizations so they can seize a competitive advantage.
Learn more about BMC ›

About the author

Jonathan Johnson

Jonathan Johnson is a tech writer who integrates life and technology. Supports increasing people's degrees of freedom.