Soft Skills for Software Development Teams

Soft Skills for Software Development Teams

Background

Before we discuss this subject – let’s reach a common understanding of what we mean by Soft Skills for Software Development Teams. Developing custom software requires a clear understanding of what the client needs to accomplish with the finished product. If you work in application development, you are aware that often this is a subject the client is not fully settled on when development begins, even if they have planned extensively. In fact, if the client believes they have all the bases covered in their application requirements, it is wise to be very careful and ensure they have the ability to be flexible at both a product and contract level. We all know that things will change as the product is realized and new opportunities present themselves. We also know that unexpected issues will come up during the project and the longer and more complex the project – the higher the risk will be. What we don’t know is how much change the project will need to be successful as envisioned and if that will be acceptable to the client. Realizing a product successfully requires that everyone on the development team is able to see more than the task that is in front of them and is enabled, personally and professionally, to help shape the outcomes. Without that, they are just following specifications in detail, not contributing their experience and insight fully and that can mean that things will go off the rails before anyone can pull them back. For developers to effectively provide the insight and experience they have to the project – they need to be able to use a range of soft skills.

On the other hand, no one can expect all or even some software developers to be business consultants, but in most cases, the same skills we expect our business consultants to have, can make all the difference when they are applied to the project from within the development team.

At a high level – what are these skills? Communication, negotiation, problem solving (creativity), and strategic thinking, but – within the context of the development team and its role in the project. There is a larger, more specific view of soft skills, but we will get to that later.

Agile Team, developing estimations - Soft Skills for Software Development Teams

Scio Development Center, Morelia, Mexico

The team context is critical. If the development team cannot come together to support a concept or conclusion that could be advantageous to the project, it has a near zero chance of moving forward, no matter how valuable it may be. This doesn’t discount the visionary individual who sees the opportunity for change, it simply means that before the idea can move forward – the individual needs to exercise their soft skills to bring their team on board as a first step. And if the team does not feel enabled to exercise their creativity and insight, their soft skills for the concept, it will never happen.

Another common misconception is that roles like Project Manager and operations like communication are in themselves soft skills. Both areas benefit from soft skills greatly, but being a good project manager has more to do with how the role is defined than anything else. In larger teams, where the project manager is more of an administrator and deliverable coordinator, more of the work is defined by procedures, checklists, and project plan maintenance than soft skills, although certainly if the plans go wrong, negotiation becomes key. In these larger scenarios, communication also becomes bound up in processes and notification cycles that are often automated, if not run by assistants and procedures. In smaller agile teams, like we use at Scio for agile software development, soft skills are always important because there are fewer intermediaries and roles between the client and the development team. In general, while procedures certainly exist, they are more flexible and can be changed to fit the context of the project quickly. In these situations, there is little to no buffer between the development team and the key stakeholders on the client team. The better the members of the team are at leveraging soft skills, the better off the whole project will be. Smaller teams have to be creative, able to communicate their ideas and support them with analysis and strategy, and finally negotiate a path to a better outcome.

Is there a process under it all?

There is a process that ties together all soft skills that – when it is done right – makes all the difference.  It is the process a team or individual uses to arrive at a conclusion for presentation, negotiation, and hopefully, acceptance. It is basically the same system a business analyst uses to present findings, but it needs to rely more on arriving at the conclusion as something everyone in the team can agree to and support. I bring this up because although all soft skills can be used by themselves, it is easier to see the value if you put them in the context of developing a proposal for a change in a project.

Soft Skills in Proposal Development

 Considering the steps

  • Gather Information
    • Open, contextual questions delivered with empathy. As you gather information, conversations and the questions in them need to be developed within the context of the organization and with an understanding (empathy) for the people you are talking to. The communication soft skill of developing questions to gather information and delivering them with empathy has considerable value and too often ignored. Not using it properly results in few useful answers (“yes” and “no” answers don’t give you any context) and little understanding of underlying drivers.
    • Research – Of course, the skill of analyzing sources is critical, but so is using the team and peers as resources in research. They will bring different points of view and experience that can be expose additional lines of discussion.
  • Analyze
    • Document Scenario – Analysis must be based on the scenario under consideration and it must be documented clearly and agreed on by the team.
    • Record Analysis – The analysis, under the scenario, needs to be referenced to the research and interviews
    • Team Inclusion – Again, the team and any peers consulted need to be pulled into the analysis through review and discussion to ensure they understand what was considered before the conclusions were reached
  • Develop Conclusions
    • Attach to research and analysis – by the time you reach the conclusions, you should be able to draw clear lines between the research, the analysis and the proposed conclusion. Referencing back to those areas is key to achieving a collaborative conclusion.
    • Team Inclusion – Of course, if the team is going to support the proposal, they have to understand the conclusions and how they were reached.
  • Reassess
    • Record Current Context – Document the current scenario and how it has changed.
    • Cycle Back through the steps and document, changing as needed and adding new conclusions.

The process of developing proposals will use all the general skills above and if we get more granular, some more as well. Ultimately, they are the skills teams need to be successful and clients need to make decisions and gain confidence in their development team. But, the development team should not wait until the problem that needs to be solved is so big that it takes days and reams of paper to present. At that point, it is too late for the team to intervene because of project timelines and pressures. If problems are recognized early and conclusions are well-documented, they should be able to be presented in a short PowerPoint presentation.  That is a much more realistic target for a development team if they can leverage their soft skills effectively.

A more comprehensive list of soft skills for Software Development Teams?

We’re not going to go into detail with the list we use of soft skills for our team training – but it is a good look at what we find useful to bring development team members to a level that improves their ability to add value to a project from their experience and insight:

Thought Skills

  • Associative Thinking (Connect the Dots)
  • Analytical Participation
  • Effective Questioning & Participation

Team Skills

  • Cultural Integration
  • Collaboration & Coordination
  • Key Stakeholder(s) Identification, expectations, Concerns
  • Teamwork & Success (also a personal skill)

Personal Skills

  • Time Management (also a team skill)
  • Always Learning, Improving
  • Self-Confidence, Interpersonal Skills

These areas, laid against the normal team analysis, project management and delivery skills required for software development, bring a better experience for clients and higher job satisfaction for our team members. But with that understanding of the “why” behind a focus on soft skill development, the biggest barriers must also be understood:

  • Soft skills do not come easily, especially in the areas of communication, collaboration and negotiation. Everyone must practice, fail, reassess, and continue the cycle to improve self-confidence and the interpersonal skills that are so important.
  • Soft skills take time to develop and in the end, have to come from hands-on experience. One class, one try, does not suffice for training. The ball needs to be passed around so that everyone can get time to gain the confidence necessary. It is like driving a car – you cannot watch a series of videos on Youtube and expect to drive a car properly. You need to get into an actual car and feel what happens as you are moving along to learn and grow.

How can you get value out of soft skills?

As a software developer, can you remember situations where you saw a solution to a problem that you couldn’t properly communicate to your team or client? If you have any experience, you have. Taking some time to research, experiment, make mistakes, ask someone to mentor you in soft skills, can make all the difference. If you have mastered some soft skills, mentor others by doing – don’t wait for them to ask.

As a client, look for ways to support your team and enable them to leverage their soft skills. There is no question we are all made smarter by working together and it lowers the burden on you and your team. You can’t expect all ideas from y0ur development team to be acceptable – but the richness possible from an inclusive, collaborative environment can increase your chances of success and decrease your risk considerably.

As we move forward to achieve better outcomes and a more positive customer experience – custom software development must continue to look for opportunities to lower risk and achieve better outcomes. Development teams can act more as partners in product development and success and less as commodity labor. It is a vision we need to continue to work on – and realize – one person, one team, one project at a time.

The Importance of Having Business Management Software

The Importance of Having Business Management Software

Every business, big or small, has a great number of activity going on at all times and has a lot of things that they need to keep track of. This is why businesses ranging anywhere from a large chain to a singular freelancer can benefit greatly from a business management software. A business management software is a software or set of programs that has the ability to perform certain business operations as well as the ability to measure and increase productivity. When you are first starting out you may be trying to keep it all in a spreadsheet or, if you’re a freelancer, you may just try to keep it all in your head. As good an idea as this may sound at first, it will likely end up in chaos and your business will suffer for it.

Why Business Management Software is so important!

Business Meeting - Business Management SoftwareOne of the biggest reasons that you will need a business management software in place is the previously mentioned measurement of productivity. When you are beginning a new business endeavor it is crucial that every employee or component of the business be working at optimal productivity. If your employees or you yourself are taking the time to do the tedious tasks that the software can do, you will be wasting precious time that could be applied to more important tasks. By using the software in place of manual labor, you will free up a lot of time to spend on customers and building your business!

This software will also help employers and business owners to see what their employees are doing with the ease of just a few clicks. This is through the calendar that makes it possible for employees to check in. You can also assign a project to any given employee and track it through this same software. This means that you won’t have to chase down the project leaders to find out the status of a project!

You can also save important documents through this software. Because it can bog up computers when you have all of the documents saved on your hard drive you have limited options. One option is to have external hard drives. However, it can take a while to go through multiple external hard drives when you are looking for a specific document. This is where a business management software comes in handy. Once documents are created they can be automatically saved into the software and they will be in arm’s reach whenever you need them!

How to choose a Software Solution?

How to Choose - Business Management SoftwareOverall, there are multiple ways that a business management software can help your business to grow and succeed. They can be a pricey software but they are definitely worth it if you find the right one. A good idea would be to choose one that has a free trial and allows you to take any data with you when you leave if you decide not to proceed with them. This will allow you to make an educated decision on what you want in your management software. Having this software in place is definitely something that you should do as early as possible to get optimal use out of it.

An even better choice is to invest in a custom business management software because that means that it will be tailor made for your specific needs and wants. This will make it even more helpful for you and your business. When you’re thinking about your business, you will want to get the best software possible and that is custom software in most cases!

10 Hidden Costs of Outsourcing

10 Hidden Costs of Outsourcing

Outsourcing is a standard practice in the software development industry and it continues to experience steady growth, year after year. Among the common drivers cited are lowering costs of outsourcing, rapid acquisition of skilled resources,  and avoiding staff overhead for one-time projects that would result in layoffs after completion.

In other words – it is all about costs in one way or another, whether they are real expenses or lost opportunities because you could not bring together a new team for a project in time to achieve your market. But, when you have paid the invoices and implemented your new application, what is on your balance sheet? Did you really save the money you thought you would? Are there hidden costs that have drained all the benefits out of the engagement?

10 hidden costs of outsourcing you may not be considering (in no particular order):

#1 – Deciding that driving cost to the lowest level possible is your primary goal

dollar-signs - Costs of OutsourcingAre you confused? If outsourcing is all about costs, how can it be that using lower costs as your primary reason for outsourcing would actually end up costing you more?

  • The lowest cost vendor cannot also be the best equipped with the best resources, deep expertise, strong cultural fit, high reliability and excellent real-time communications in your language. Solving each of the issues mentioned has a cost to the vendor, during the contract period or before to find, train, and maintain the necessary resources. Pushing to the lowest possible costs will require trade-offs that you and your team will bear. You may be able to anticipate the cost of working with less experienced and less independent resources at a production level, but can you also judge the costs that could come when unexpected issues arise? Have you ever experienced a project without unexpected issues? Really?
  • Often, when price is the primary driver, the service buyer decides to manage costs by requiring a fixed-price bid. The upside is the risk is placed on the outsourcing vendor. To mitigate their risks, the vendor will then require extensive documentation, a detailed waterfall-type project plan that leaves acceptance testing to the end of the project, and penalties or prolonged negotiation if changes are needed. Plus, to pad for risk, the vendor will actually increase their bid because they know that fixed-price engagements rarely finish on time and within budget. In addition, they may decide to use less experienced resources (lower cost) overseen by senior resources (high cost, but with little time to look deeply into design and coding issues), So, in the end, instead of gaining assurance the project will end on time with an expected cost, the buyer has more cost for upfront specifications, more risk the final application will meet specifications as written but fail to achieve its goals, and much less oversight and flexibility once the project begins. The vendor will manage to the contract requirements and not the business goals their client decided were important internally. The vendor takes the entire responsibility for cost control, quality assurance, and management. In most cases, this means if their timeline or costs get out of line, quality control and communication between the development team and the client team will suffer.
  • If your primary driver is cost, you will probably be pushed to offshore resources that are very low cost but have difficulty making their teams available in real time to collaborate with your team, lack good communication skills in your language and little in common with your culture. In these cases, you will have to  do what you can to mitigate the fact that 28% of projects fail because of communication issues and 16% fail because of poor cultural matches.

#2 – The cost of selecting a vendor

Costs of Outsourcing

Few buyers have a budget for selecting an outsourcing vendor and if they do, they rarely allow for the work that would really contribute to successful projects and relationships.

  • Up-front requirements and bidding document preparation. In order to assure all vendors provide comparable bids, considerable time needs to be spent, by your in-house team specifying both the project and the vendor requirements. If a number of non-compliant or non-comparable bids are returned, what is the cost of going back to the vendor with more details and allowing other vendors to update their bids with what is perhaps new information or different assumptions for them? The hourly cost of internal staff, consultants or both add up but are often not counted in the final project analysis.
  • Time and opportunity costs. Depending on the value of the project, the vendor selection process can take 4 months to a year. This includes selecting the vendor pool, preparing documents, sending, receiving and reviewing documents, negotiating and preparing contracts, demonstrations, travel to selected vendors, and more.
  • Travel costs. To properly evaluate final round vendors for a strategic project, it is imperative that is spent at the data center or workplace of the vendor team to assure that practices and conditions match expectations. The greater the distance, the greater the actual costs and the time required for travel. Typical round-trip times to India and Asian locations are two to three weeks depending on the goals and number of vendors to be visited.

#3 Project initiation

The costs of project initiation have an inverse relationship with project risk. The less you spend on project initiation, bringing the teams together, assessing process and methodology, assuring communication, respect, and team collaboration is strong, and that there is a shared understanding of project goals, the greater the risk that the project will fail. But even knowing this simple fact, most vendors and buyers will decide to cut the project initiation phase in favor of “getting to productive coding” quickly. The downside of this choice is a longer time to reach full productivity, more risk of rework to meet expectations, and increased costs for project oversight and team management.

#4 Staff transition

When a new outsourcing team is started on a project, internal staff is often given new roles as part of the initiative. They could be tasked as product owners, to oversee user story development, to run internal quality and acceptance testing, or to assure that questions that cannot be handled directly by the internal product team are handled quickly by the right subject matter experts. If the outsourced team cannot work during the standard workday of the client team, the daily schedules of the internal team may have to be shifted drastically. Their existing roles and responsibilities will need to be handed off or reprioritized to allow them the time to handle their new work and the task switching that invariably occurs. The costs of transition (and retraining in the case of those that may be new to methodologies like agile) are rarely considered in project costs but in reality, if they are not allowed for, the resulting issues can be very costly.

#5 Infrastructure & operations realignment

Inevitably,  a new outsourcing project will incur changes in local infrastructure and software development operations. The changes may include new virtual environments, changes to internal processes for continuous integration, automated testing, security and authentication, incremental releases to production or many other issues. Again, part of this falls to poorly planned project initiation, but even with upfront time focused on team cohesion and user stories, the requirements for infrastructure and operations are often overlooked. When they are, count on additional costs because of lowered productivity as issues are ironed out and everyone gets on the same page.

#6 Contract & relationship management

Throughout the project, the buyer/client-side project manager needs to assure that incremental payments match the effort spent and the deliverables received as well as the necessary progress toward completion. Not spending enough time on this aspect of the project can result in very tough negotiations if the project goes off track or unexpected issues arise. In addition, selecting the right project model, whether it is fixed price, time and materials, dedicated team or another variation, has a big impact on this area. A lack of trust and understanding or lack of partner-level communication during the project can make a project very hard to manage to a successful conclusion and very costly when issues must be resolved.

#7 Cultural & organizational alignment

It may seem like a “soft” issue, but if the outsourced team and vendor cannot navigate your cultural norms and organizational environment it is likely to make project management very difficult. Bringing a team from a hierarchical culture into an organization with a flat structure can be very disorienting to team members with different expectations for interaction and responsibility. Merging a small team into an enterprise system with many silos and layers of control can be very difficult. The new team in either case will require additional time to reach full productivity and oversight to ensure they can fully participate as expected – and has a real cost.

#8 Intermediaries

Hierarchy - Costs of OutsourcingTo mitigate many of the issues in this list, outsourcing vendors and buyers often impose intermediaries on projects as an extra layer of “assurance.” This imposes two extra layers of cost on a project: The direct cost of the extra labor required and the indirect cost from the risk incurred when developers, product owners and subject matter experts do not regularly engage in project discussions directly. Every time an intermediary becomes involved, there is a loss of fidelity and clarity. In the end, instead of assuring better communication, the sides are pulled into a “blame-game” when issues are not fully explored or questions are “translated, collated and summarized.”

#9 Technologies

The selection of technologies for a new project can have significant impact on project and application success. If the internal team restricts choices because of a lack of understanding and confidence in the options offered by the outsourcing team, if a lack of communication results in a poor understanding of risk and downsides of technologies selected, or if choices are avoided to keep from exposing a lack of awareness – the downsides can be very hard to overcome. They can raise “technical debt” to a degree that limits options “down the road” in the project or the application lifecycle and lower team cohesion to the point that trust and communication are lost completely.

#10 Location, location, location

To a degree, we’ve covered this already in the sense that work time overlaps, cultural fit, and communication issues can cause project costs to rise significantly. But on its own, the location of the outsourcing team in relation to the client team should be a part of vendor selection, a factor in project initiation, and a major concern from the beginning of any outsourcing relationship. The greater the geographic distance between the teams, the greater the issues will be. Mitigation costs, in general, will increase including travel, working hour adjustment, intermediaries, communication, contract management, etc. While considering nearshore vendors will not eliminate all outsourcing risks and issues, they can make other choices much easier to deal with and diminish risks significantly if they have the right resources and ability to work at a partner level with your team.

Outsourcing can save you time and money, but only if it’s done correctly. With so many factors to consider, it’s important that you do your research before making any decisions. The 10 points above are a great starting point – but there are still more software development costs to think about, such as marketing development costs and advertising expenses. By taking the time to understand all of the possible hidden costs associated with outsourcing, you can be sure that you’re not overspending on your project.

Scio is a nearshore vendor of software development services for our clients in North America. We tune our project model to the project at hand and operate with our clients at a partner level to lower risk on both sides. If you would like to discuss your next project and the options we can offer, please contact us. We would be happy to work with you.