Welcome!

Java IoT Authors: Liz McMillan, William Schmarzo, Elizabeth White, Pat Romanski, Ed Featherston

Related Topics: Java IoT

Java IoT: Article

Java Development Managers Stress the Need to Improve Software Quality

Lack of attention early in the development cycle negatively impacts the code's entire lifecycle

We've all experienced it - the "get it out the door" mentality that seems to be the driving force behind many software application deliveries - a prime example of the software industry's immaturity that favors completion over quality, and an end user's preference for hot new features over stable, reliable systems. Deferring the QA process is an expensive way to operate and corporations are taking a financial hit for these software errors. According to the Washington, D.C., National Institute of Standards and Testing (NIST), software errors cost the U.S. economy $60 billion per year. This report was issued back in 2002 and, since then, the software industry has done little to improve the situation.

Why are software bugs so pervasive? We don't accept these same poor standards in other industries, so what makes software exempt? Some say it's the inherent complexity of systems and software that are the primary causes of application failure, or that poorly defined system requirements and unrealistic schedules are at fault. Others blame it on developer apathy. Most of the time, however, software failure is the direct result of poor quality code, brought about by a lack of standards and metrics in the development phase.

A Clear Horizons market research study, commissioned by Enerjy Software, identified key code quality issues that impact software development managers. First, quality tracking begins too late, if at all, to be effective. According to the study, 40 percent of Java software development managers surveyed have allotted time for checking code quality, but only in less than half of their projects. In projects where quality is being measured, nearly 30 percent did not measure code quality until the project was more than half completed. This lack of attention early on in the development cycle has a rolling negative impact for the entire life cycle of the code.

Focusing on Code Quality
The study found that most Java software development managers view code reviews, the traditional method of improving code quality, as inefficient and a source of frustration. With all the competing demands on their limited development resources, it often falls by the wayside. As a result, the act of fixing a bug may be the only time their code is actually reviewed. By that time, it is too late.

Development managers are demanding a change from the "fire fighting" mentality prevalent in the industry. However, this change needs to come from IT executives who must take the lead in establishing best practices that focus on quality across the entire software development lifecycle - from requirements gathering to deployment and beyond. Applying best practices to help achieve software quality must become a mindset that is filtered from the top down and includes:

  • Requirements definitions
  • Unit testing
  • Coding standards adherence
  • Change and version control
  • Quality assurance testing
  • Software maintenance post-release
It is imperative that quality initiatives begin before the first line of code is written. A key reason for software project overruns is that the time needed for the QA phase is usually grossly underestimated. This is because the QA phase should be used for functional testing, i.e., checking that the application does what it is supposed to do. Instead, too much time is being consumed in the QA phase, finding and fixing bugs that should have been fixed in the development phase. Errors need to be identified and prevented from progressing through the development cycle, because, as everyone knows, it's more costly to fix bugs later in the development process than at the beginning.

Early in the development cycle, developers need to define coding standards, adhere to them, and ensure that all code is unit tested. By applying coding standards and unit testing at the development stage, many potential bugs will never occur. During the quality assurance phase, standardized testing tools, suites, scripts, reference data, and metrics that have undergone a rigorous certification process can improve software integrity even more.

A focus on code quality enables development teams to optimize the quality of an application before it reaches production. Such a QA process will help to make testing less costly to perform, as well as provide a consistent method for determining when testing is sufficient. The focus on code quality throughout a Java application's life cycle will enable development teams to fix bugs and add new features within schedule while improving overall product quality.

Who's Responsible?
While software developers are responsible for maintaining or improving bad code, it is the development managers who are directly responsible for code quality. Their jobs are to deliver code that works and, with the same resources, ensure that critical bugs are identified and fixed in a timely manner - an almost impossible balancing act.

In fact, buggy code is the "Sword of Damocles" for all software development managers. It's what hangs over their heads and keeps them awake at night. According the aforementioned study, the number one complaint of Java software development managers is their inability to minimize software bugs in code before it is released. This study, completed in 2005, was conducted on a sampling of 216 Java software development managers who manage five or more Java developers.

Tasked with delivering quality code, how can Java development managers best facilitate quality processes? What are their primary challenges? What tools do they need to accomplish their objectives? It makes sense that a focus on quality is essential for the success of any software application.

Stressing the Importance of Code Quality in the Development Environment
Though development managers take the heat for missed deadlines, wasted development resources, and poor application quality, software development organizations have primarily focused on providing developers with the tools, infrastructure, and training for developing software applications.

While it is easy to blame software errors on developers - sloppy coding techniques, arrogance, and an insistence upon the freedom to create - it may be the development environment itself that is the problem. Typically, development managers have been promoted from within the development ranks due to their outstanding technical abilities and may not have had previous management training or experience. Often, they receive generic management training and technical training on par with their subordinates; however, this is not enough. Today's management and lead developers are stuck in a cycle of poor code and bug fixing, without the corporate backing required to identify issues and initiate software development best practices.

Another issue presented in the report is the lack of quality metrics available to Java development managers. A majority of the Java development managers in the Clear Horizons study reported frustration with developers not following Java best practices or coding standards, or producing "off-spec" code - yet they had no way to track this information via quality metrics. Without these quality metrics, development managers have no idea who is creating the bad code, or what percentage of that code adheres to standards or is being unit tested. As development managers, their primary objective is to prevent or minimize bugs. Without an in-depth understanding of the importance of code quality relative to individual developer performance, they are flying blind.

Most developers prefer to work in a structured development environment that supports best practices, because it offers relief from "fire fighting" and damage control. By introducing best practices into an organization's development environment, developers will find errors early, streamline the build processes, reduce overtime, and become clear on their roles within the organization.

Improving Tomorrow's Software Quality
With maintenance costs exceeding 90 percent of organizations' IT budgets, it is imperative that development managers work to transform their team's behaviors from reactive to proactive: instilling best practice tactics that focus on superior code quality and increased application development excellence. To do this, there must be greater emphasis placed on the quality of a team's deliverables at all points within the development cycle.

Java software development teams want to create quality code. Their apathy and resistance to change is often due to a stagnant development environment, over which they have little control. Teaching them about the benefits of best practices, such as the adherence to coding standards and thorough unit testing, is not enough. Most developers have already been exposed to these methodologies. Development managers, who are ultimately responsible for code quality, often feel they have their hands tied. Compressed schedules, unknown developer performance - especially with new hires and novice developers, the absence of best practices and controls, and a bug count that sidetracks resources from competitive enhancements, all conspire to keep them from sleeping at night.

In order for best practices to take hold, IT management must implement these best practices across the development team and promote code quality as a mindset from the top down. Development managers have to promote coding standards initiatives that are easily embraced by all developers and enact processes and procedures, such as source code control systems, that streamline processes, and unit testing, to eliminate many potential bugs before the software is released to Quality Assurance.

What Java development managers need most of all is a quality measurement system that institutes code quality metrics and helps them track and train developers, so that they can meet deadlines with high quality software that conforms to internal standards and exceeds customer requirements. Such a system would give Java development managers a greater sense of control over their development team and the quality of code that they produce.

More Stories By Nigel Cheshire

Nigel Cheshire is CEO of Enerjy Software, a division of Teamstudio Inc. He oversees product strategy and has been driving the company's growth since he founded it in 1996. Prior to founding Teamstudio, Inc., Nigel was co-founder and principal of Ives & Company, a CRM solutions consultancy. He holds a Bachelor of Science degree in computer science from the University of Teesside, England.

Comments (1) View Comments

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


Most Recent Comments
SYS-CON India News Desk 05/08/06 12:49:55 PM EDT

We've all experienced it - the 'get it out the door' mentality that seems to be the driving force behind many software application deliveries - a prime example of the software industry's immaturity that favors completion over quality, and an end user's preference for hot new features over stable, reliable systems. Deferring the QA process is an expensive way to operate and corporations are taking a financial hit for these software errors. According to the Washington, D.C., National Institute of Standards and Testing (NIST), software errors cost the U.S. economy $60 billion per year. This report was issued back in 2002 and, since then, the software industry has done little to improve the situation.

@ThingsExpo Stories
SYS-CON Events announced today that Daiya Industry will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Daiya Industry specializes in orthotic support systems and assistive devices with pneumatic artificial muscles in order to contribute to an extended healthy life expectancy. For more information, please visit https://www.daiyak...
SYS-CON Events announced today that Nihon Micron will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Nihon Micron Co., Ltd. strives for technological innovation to establish high-density, high-precision processing technology for providing printed circuit board and metal mount RFID tags used for communication devices. For more inf...
SYS-CON Events announced today that Massive Networks, that helps your business operate seamlessly with fast, reliable, and secure internet and network solutions, has been named "Exhibitor" of SYS-CON's 21st International Cloud Expo ®, which will take place on Oct 31 - Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. As a premier telecommunications provider, Massive Networks is headquartered out of Louisville, Colorado. With years of experience under their belt, their team of...
SYS-CON Events announced today that Suzuki Inc. will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Suzuki Inc. is a semiconductor-related business, including sales of consuming parts, parts repair, and maintenance for semiconductor manufacturing machines, etc. It is also a health care business providing experimental research for...
SYS-CON Events announced today that mruby Forum will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. mruby is the lightweight implementation of the Ruby language. We introduce mruby and the mruby IoT framework that enhances development productivity. For more information, visit http://forum.mruby.org/.
Elon Musk is among the notable industry figures who worries about the power of AI to destroy rather than help society. Mark Zuckerberg, on the other hand, embraces all that is going on. AI is most powerful when deployed across the vast networks being built for Internets of Things in the manufacturing, transportation and logistics, retail, healthcare, government and other sectors. Is AI transforming IoT for the good or the bad? Do we need to worry about its potential destructive power? Or will we...
SYS-CON Events announced today that B2Cloud will exhibit at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. B2Cloud specializes in IoT devices for preventive and predictive maintenance in any kind of equipment retrieving data like Energy consumption, working time, temperature, humidity, pressure, etc.
In his session at @ThingsExpo, Greg Gorman is the Director, IoT Developer Ecosystem, Watson IoT, will provide a short tutorial on Node-RED, a Node.js-based programming tool for wiring together hardware devices, APIs and online services in new and interesting ways. It provides a browser-based editor that makes it easy to wire together flows using a wide range of nodes in the palette that can be deployed to its runtime in a single-click. There is a large library of contributed nodes that help so...
What is the best strategy for selecting the right offshore company for your business? In his session at 21st Cloud Expo, Alan Winters, U.S. Head of Business Development at MobiDev, will discuss the things to look for - positive and negative - in evaluating your options. He will also discuss how to maximize productivity with your offshore developers. Before you start your search, clearly understand your business needs and how that impacts software choices.
SYS-CON Events announced today that SIGMA Corporation will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. uLaser flow inspection device from the Japanese top share to Global Standard! Then, make the best use of data to flip to next page. For more information, visit http://www.sigma-k.co.jp/en/.
SYS-CON Events announced today that NetApp has been named “Bronze Sponsor” of SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. NetApp is the data authority for hybrid cloud. NetApp provides a full range of hybrid cloud data services that simplify management of applications and data across cloud and on-premises environments to accelerate digital transformation. Together with their partners, NetApp em...
Agile has finally jumped the technology shark, expanding outside the software world. Enterprises are now increasingly adopting Agile practices across their organizations in order to successfully navigate the disruptive waters that threaten to drown them. In our quest for establishing change as a core competency in our organizations, this business-centric notion of Agile is an essential component of Agile Digital Transformation. In the years since the publication of the Agile Manifesto, the conn...
There is huge complexity in implementing a successful digital business that requires efficient on-premise and cloud back-end infrastructure, IT and Internet of Things (IoT) data, analytics, Machine Learning, Artificial Intelligence (AI) and Digital Applications. In the data center alone, there are physical and virtual infrastructures, multiple operating systems, multiple applications and new and emerging business and technological paradigms such as cloud computing and XaaS. And then there are pe...
Real IoT production deployments running at scale are collecting sensor data from hundreds / thousands / millions of devices. The goal is to take business-critical actions on the real-time data and find insights from stored datasets. In his session at @ThingsExpo, John Walicki, Watson IoT Developer Advocate at IBM Cloud, will provide a fast-paced developer journey that follows the IoT sensor data from generation, to edge gateway, to edge analytics, to encryption, to the IBM Bluemix cloud, to Wa...
SYS-CON Events announced today that MIRAI Inc. will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. MIRAI Inc. are IT consultants from the public sector whose mission is to solve social issues by technology and innovation and to create a meaningful future for people.
While some developers care passionately about how data centers and clouds are architected, for most, it is only the end result that matters. To the majority of companies, technology exists to solve a business problem, and only delivers value when it is solving that problem. 2017 brings the mainstream adoption of containers for production workloads. In his session at 21st Cloud Expo, Ben McCormack, VP of Operations at Evernote, will discuss how data centers of the future will be managed, how th...
SYS-CON Events announced today that Keisoku Research Consultant Co. will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Keisoku Research Consultant, Co. offers research and consulting in a wide range of civil engineering-related fields from information construction to preservation of cultural properties. For more information, vi...
SYS-CON Events announced today that Fusic will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Fusic Co. provides mocks as virtual IoT devices. You can customize mocks, and get any amount of data at any time in your test. For more information, visit https://fusic.co.jp/english/.
SYS-CON Events announced today that Enroute Lab will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Enroute Lab is an industrial design, research and development company of unmanned robotic vehicle system. For more information, please visit http://elab.co.jp/.
SYS-CON Events announced today that Mobile Create USA will exhibit at the Japan External Trade Organization (JETRO) Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Mobile Create USA Inc. is an MVNO-based business model that uses portable communication devices and cellular-based infrastructure in the development, sales, operation and mobile communications systems incorporating GPS capabi...