Completely random stream of thoughts about the software business, from the perspective of an executive.
Friday, August 29, 2014
When opportunity knocks
Tuesday, June 24, 2014
Learning
Monday, May 5, 2014
Solve the problem class, not the instance
When correcting either defect, it is typical to update the system to handle the unexpected user input. This is where most people stop. Since systems are built using patterns and models, a defect in one part of the system has likely been introduced elsewhere. Generally, solutions to reported failures miss opportunities to identify and resolve the underlying class of defects.
When faced with a failure report from the field (or internal QA), go deeper. While more an art than a science, there are several questions to ask that may reveal additional latent defects:
- Where else is this programming model used? (E.g., the pattern is used in all our repositories)
- How can the specific user input be generalized? (E.g., a screen blows up because one piece of information was made inactive by the system administrator, but other types of information can also be made elsewhere)
- Where else can these type data be entered? (E.g., Dates prior to today can be entered in many places)
Cultivate this perspective by starting with these questions and extending them to your environment. Encourage people on your team to generalize every failure reported. The goal is to get past the specific instance of the failure and to consider the class to which the failure belongs. You may elect to only repair this instance due to time or money. At least you will be doing so consciously. Alternatively, you may find that you identify and avoid serious field failures.
You may elect to only repair this instance due to time or money. At least you will do so consciously. Alternatively, you may find that you identify and avoid serious field failures.
Sunday, June 9, 2013
Big rewrites: Summing things up
- Iterate
If possible, break the rewrite into smaller chunks. Determine the smallest amount of business value you can deliver and start there. This allows you to stay focused on software delivery fundamentals and to use the new technology in the real world. Release management, branching and merging, and patching are just a few of the processes I've seen atrophy after years of rewriting software without a delivery. - People
A blended team of existing folks and new hires is desired, but comes with issues that require supportive, yet firm, management. The technology transition is going to happen - that is where you must remain firm. It is not reasonable to expect your existing team to learn a new technology stack in the context of significant business implications. You will have acquire skills and that will cause friction. These new folks have to be integrated into a new, combined team. - Skills
The existing team members are a key to success due to expertise of the system, customers, and industry. Your commitment to their education, skills, and to be blunt - employment, is the supportive aspect. Show them how they will participate in the transition itself, as well as their contribution in the new world after the change. Provide them a picture of their role after the new technology is in place to assure them that they aren't helping the "new folks" build the system that is putting them out of a job.
Friday, May 3, 2013
System migration and people: Part 2
This presents a fundamental challenge to large-scale technology migration. And one of the greatest ironies.
Possession of the required new skills is the least important contribution from your existing team. Yes - you read that right. During this transition, what makes your existing team so valuable is not their technical skills. So what does?
- Domain knowledge
No matter your business, there is specialized domain knowledge. Mine is healthcare. That means deep understanding of patient registration, ordering medications, patient care documentation, and scores of other complex workflows. These don't change with new technology. Your team has spent years learning these and the interplay among them. - Customer understanding
Your team understands how your customers operate at the intersection of the current product and the domain. You can't do a migration without some consideration for your customer base. Your team has customer relationships and trust (hopefully) to increase the chances of the transition going smoothly. - Organizational knowledge
As I wrote last time, you may supplement your team with expertise in the new technology. These folks aren't going to have a clue about anything related to the items above. Your team can help them navigate the challenges of finding information about the existing system and processes - or even who knows the answer in the first place.
Monday, April 29, 2013
System migration and people: Part 1
My last post discussed migrating to a new technology stack as part of extending the life of a software system. Next, I'll explore people considerations. The first topic is skills related to the technology stack. My next post will discuss the role of domain experience. Finally, I'll attempt to tie it all together with a summary post.
Chances are your current team possesses skills to evolve and maintain the existing system. Unfortunately, these may not be the technical skills needed by the new technology stack. This may be a source of fear among the team. While there are no easy solutions, here are some thoughts:
- Get expertise in the new technology stack
The most effective way I've seen this done is to hire additional people to supplement the team. Find people who know the new technology well and have demonstrated its use in bringing to market solutions that have some matching characteristics to your product.
You need people with experience, otherwise you will end up with the old solution implemented in new technology - not at all what you intend.Your goal is to quickly apply best practices with the new technology. Consultants have their place, but in this situation I find that nothing beats employees who are fully dedicated to the project.
- Commit to trainingFor those who want to, provide training in the new technology. It's OK if some want to stay with the older stack. it will be around for a while and you will need to maintain it. However, show people that you are willing to invest in their future and they will be more likely to stay with you through the transition.
In addition to training, integrate new employees with existing teams to increase the pace of learning. This will create one team, demonstrate by example how to apply the new tech stack, and allow new employees exposure to existing rationale, business rules, and architecture.
Understand that for some, they will equate their value to their existing skills. My next post will address this directly.
Monday, May 31, 2010
Getting Change Done
No executive wants to cause her team additional stress. On the other hand, no executive wants to maintain status quo and allow his business to fold. Navigating this tension is difficult. Here are a few things I’ve learned along the way to ease (but not eliminate) this tension.
Start doing, stop talking
Once you know the direction you want to go, start walking. Planning is needed, but not at the expense of learning. You seldom know how things will turn out, so begin to execute and make adjustments. Plan enough to get you started and to share the general direction and goals with key team members. That may mean a few hours or a few weeks – that depends on the scope and magnitude of the strategy to execute. Here are some recommendations:
- Encourage key team members to find the quickest items to start executing, as well as defer everything that doesn’t need to be known immediately.
- Reinforce to them you aren’t looking for perfection and you expect adjustments to be made continually along the way.
- Lay out significant milestones and ask for a plan to achieve them. They own the plan (how); you own the results (what).
Stay focused on the storyline, not the sentences
I recently worked with my team to deploy a new (to us) suite of development tools. Do I agree with every configuration and option the team selected? In honesty, I can’t answer the question because I don’t know every configuration and option the team selected. I am pretty sure if I reviewed every choice, there are things I would do differently.
That doesn’t matter.
What matters is that the tools are deployed effectively to increase the efficiency of the development team. In other words, allow the team to determine how the change is implemented. The message to the team is twofold: I trust you to make good enough (not perfect) decisions and I trust you to make course corrections as needed.
Acknowledge the team’s discomfort
It is normal (and part of being human) to feel anxiety and excitement simultaneously during changes of direction. Knowing that feeling frustrated and anxious is normal won’t stop the pain, but it is enough for most people to help them get through the change.
- Be there to help them work through the initial angst. When the first set of people emerge “on the other side”, enlist them to help bring others across.
- Remain firm that the direction is not negotiable (keep in mind if you really blew it, then of course redirect – for now assume your direction is appropriate). Some people may continue to resist, but strangely, knowing that you are committed is reassuring to them.
In the end, How much is too hard to push? If you are moving people out of their comfort zone, then aren’t you making them uncomfortable? And is that bad?
These questions have been buzzing around in my head for years. I’m not sure there is a right answer. More than likely, there isn’t.