We pickup from the Why I loathe when engineers use TLAs, such as CD vs CD! and switch gears to the need for a common language. Establishing a shared terminology (common language) for technical terms in an IT environment is key to avoiding miscommunication, saving time, and ensuring teams work together effectively on complex projects. One of our first Center of Enablement (CoE) working groups aimed to create a glossary of common TLAs, business terms, and technical terms to clarify our written and verbal communications.
One of our first Center of Enablement (CoE) focused working groups was focused on creating a glossary of common three/four-lettered acronyms (TLAs), business, and technical terms to ensure we all know what we are talking about in written and verbal communications. Naturally, its effectiveness relies on people being able to find and use it.
In combination with the common language, our suggested way to communicate is to use the format: WHAT
ASK WHY
. For instance, rather than saying "Delete my repo XYZ", say "Delete my Azure DevOps (AzDO) Azure Repo XYZ,
WHAT + ASK + WHY = ACTIONABLE
The latter question will result in less back-and-forth communication, confusion, and dramatically reduce both frustration and lead times, because the communication:
- Is clear and precise, minimizing mistakes, confusion, and delays.
- Provides context to explain WHY we are undertaking certain actions.
- Enhances accountability by clearly documenting the WHAT and WHY.
- Helps with prioritization with cues like decommissioning.
- Is ACTIONABLE, avoiding unnecessary clarification steps.
Let us explore three examples from our operational support bucket to highlight the issue.
Help, my PROJECT is broken!
We begin with a simple, yet typical example.
Imagine being an engineer handling Azure DevOps services and receiving three requests saying, "My project is broken!"
Questions that will pop into your mind include:
- WHAT project?
- WHERE can I find more details about it?
- HOW is it broken?
- WHAT troubleshooting has the user done? Usually a futile question.
You need to start a discussion with each user to get these answers before you can understand and prioritize the issue.
While waiting, you might investigate who the users are and assume they refer to their business application, Visual Studio project, or Test project based on their profiles. I have tried this approach to be proactive, but it often leads me astray because each project context is unique.
Here is an example by the developer persona for an actionable request:
"My Visual Studio XYZ solution is throwing an error
CODE, DESCRIPTION
in myURL
continuous integration pipeline. I have researched the error using our Stack Overflow and Google search, findingTHIS URL
information. I am working on an urgent hotfix forP1 INCIDENT ID
."
The request provides a clear, well-structured overview of the issue, along with details that enable the recipient to understand, prioritize, and act. Key parts of the revised request:
- Clear description of the issue (WHAT).
- Context and location information (WHERE).
- Shows effort made by the requestor and references outcome.
- Urgency and priority (P1).
It becomes actionable and minimizes assumptions and back-and-forth communication
In this first and simple example, the term project is used in conversation. The individual who begins the dialogue fully grasps what the project entails and the related issue, while the person being addressed has no context and thus cannot act effectively.
SOLUTION, <...> down?
In the second example, I will simply provide a few more instances of tricky words when used without context:
- Blueprint
- Code
- Container
- Goal
- Process
- Product
- Solution
- Template
- Tool
I trust you have encountered these and others in your ecosystem.
... --- ...
My ENVIRONMENT needs rescue!
Unfortunately, a recent incident involving environments not only introduced a new word with gazillion meanings for us, but also caused me to lose my temper. Not productive or healthy.
Azure is integral to our daily operations, and Azure DevOps anchors our software development lifecycle. When considering just these two environments – do not get me started with the name "Azure DevOps" – expecting two environments can mean various things.
- Azure DevOps (AzDO) environment covers the infrastructure and services which support the entire software development lifecycle (SDLC), including boards, repositories, pipelines, test plans, and artifacts.
- Azure DevOps (AzDO) Pipeline environment enables you to define and manage resources across various environments (development, staging, production) with enhanced traceability and control over deployments.
- Build and Test Environments, where Azure DevOps oversees the CI process by constructing the application and executing unit, integration, and automated tests.
- Development Environment, equipped with resources like virtual machines, containers, and services (e.g., Azure App Service, Azure SQL Database), is set up for developers to create and test their code.
- Infrastructure as Code (IaC) environments, such as Terraform or ARM templates, facilitate the management of environments through code.
- Lower/Upper Environments that delineate different stages of readiness.
- Production Environment, where the application operates and serves its users.
- Sandbox Environment, a controlled setting for experimentation, learning, and testing without impacting production or other environments.
- Staging Environment, which replicates the production setup.
- Testing/QA Environment, used for validating code changes through both automated and manual tests.
As previously mentioned, had the user requested using our WHAT
ASK WHY
approach, like "I need two Azure DevOps Pipeline environments for our infrastructure-as-code environments," the engineer would have needed fewer follow-up questions, reducing frustration and shortening lead times. In this scenario, Azure environments play a crucial role in our operations, with Azure DevOps environments central to our software development process. Requesting two environments without clarity can be ambiguous.
This recent real-world example involved three days of back-and-forth communication, made worse by the fact that two users made similar requests for different environments, engaging at least five engineers. This situation clearly demonstrates a significant amount of WASTE!
The choice is yours ...
Are you facing similar confusion and miscommunication within your IT environment? If so, how are you managing it?