I love Gene Kim’s analogy about how all unicorns used to be horses; its a great visual that I use all the time when encouraging IT organizations to change from thinking “why not” to “why not us” when it comes to starting their DevOps transformation. If culture is really one of the greatest enemies to faster adoption, then you have to start with where the horses live.
One of the biggest herd of horses in every organization is the team of people dedicated to testing and validating applications. Even though these teams are not being included in the conversation, they are in fact the most pivotal part in the transformation.
A Dangerous Love Triangle
DevOps is touted as the marriage of development and operations; a match made in heaven. One small problem though: in most traditional organizations there is a love triangle between operations, development, and testing, as the flow of bits roll from one team to the other until the application is delivered to production. With the conversation shifting to how can development and operations work better together the testing teams are being alienated. The question is where does a testing team fit into this conversation, when the focus is all about bringing development and operations closer together? How can the testing team assert themselves to help facilitate this transformation?
Horn Growing Engagement
The Phoenix Project is a great narrative that introduces robust DevOps concepts. One cannot go far on staging-devopsy.kinsta.cloud without seeing “The Three Ways” and what they mean. The first “way” is about getting a really good understanding of the delivery chain and how it works as a whole to deliver applications to the end user. The team that knows the most about this is the testing team as they are the glue that binds operations and development together. If you are going to start growing a horn, you need to start here.
Engage with the testing team early and often. This team knows more about the flow of information from development to production than any other team. They understand the process of moving applications from development environments, testing them, and delivering them to production. They understand the infrastructure and how it should work and what operations team needs to deploy applications. This knowledge is the perfect horn-growing fertilizer.
Performance-Driven Feedback
In my last post I talked about how performance and change management were two pillars to start building on. As you start to move from simply understanding the system as a whole and increasing the rate of feedback, performance data is critical. Remember, in science there is no right or wrong answer – only data that says the outcome is desired or not. Performance data can help take the emotion out of determining whether or not processes are going right or wrong after change is made. Most of the performance engineering folks are embedded in the testing groups since this type of expertise is needed to drive a successful DevOps transition. However, be careful as you start to utilize these resources as they have the potential to become your biggest constraints. Protect them and get the mechanics of performance testing and engineering out of their head and into the heads of your development and operations teams.
Continuous Experimentation
Once you have the testing team on board and helping in this process an interesting event should occur. The testing teams will start to embed themselves into Development and Operations. This is when an environment of experimentation becomes possible, just like in a factory, quality is being tested continuously. This leads to a more combined focus on the task at hand while ensuring the quality of the applications and the speed of delivery.
So really the phrase should be: DevOps, don’t fear! The testing team is here!