• Search form is empty!

  • Battling Technical Debt

    http://robertdunaway.github.io
    http://mashupjs.github.io
    The Mashup is a learning tool that also serves as a bootstrap project for line-of-business applications.

    Battling Technical Debt

    The purpose of the MashupJS is leveraging past experience to reduce technical debt moving forward.

    Technical Debt according to Wikipedia.org:
    http://en.wikipedia.org/wiki/Technical_debt

    “Technical debt (also known as design debt or code debt) is a recent metaphor referring to the eventual consequences of poor system design, software architecture or software development within a codebase. The debt can be thought of as work that needs to be done before a particular job can be considered complete or proper. If the debt is not repaid, then it will keep on accumulating interest, making it hard to implement changes later on. Unaddressed technical debt increases software entropy.”

    "As an evolving program is continually changed, its complexity, 
    reflecting deteriorating structure, increases unless work is done 
    to maintain or reduce it."
        — Meir Manny Lehman, 1980
    

    Examples of Technical Debt Reduced by the MashupJS

    MULTIPLE CODE BASES

    Maintaining multiple code bases for the same application.

    Example
    • Mobile application where each hardware platform has its own code implementation.
    • Multiple copies of a project because of multiple .NET Frameworks.
    Cost
    • Resource Cost – When dealing with multiple hardware platforms, costs are increased with the number of platforms. Each platform requires a dedicated, highly skilled resource or broader skilled resources that understand multiple programming ecosystems.
    • Increased Risk – Multiple code bases require increased testing, bug fixing, and introduce the risk that a bug fix might not make it into all code bases.
    Solution
    • The power in web technologies is the ability to run on all platforms that support a web viewer. Using a hybrid mobile approach with Cordova, Ionic, and Angular with Responsive Design, it is possible to build an application capable of running from a web browser, desktop, Android, iOS, and Windows 10 devices with a single code base.

    LACKING DEPTH OF KNOWLEDGE

    The greater the number of technologies in an ecosystem, the more shallow knowledge and experience become.

    Example
    • Over time, applications are developed for the business, but never kept up to date.
    • After a decade, in a small shop, an ecosystem might have the following:
      o Two classic ASP applications
      o Three classic ASP.NET forms applications
      o Two ASP.NET MVC applications
      o One Silverlight/EF4 application
      o Two modern web Angular/WebApi applications
      o Web Services, WCF, and WebApi
    Cost
    • Staffing Cost – Cost increases as skills diminish. With so many technologies, the number of staff required is far higher than it would be if the technologies were in sync.
    • Delivery Cost – With so many technologies, knowledge depth decreases. With decreased knowledge, support costs increase.
    Solution
    • The Mashup Core gives all applications a common set of components and services. When a core component is enhanced, all applications are enhanced.
    • Adopting a process of Continuous Improvement, the effort to keep applications updated is far less than with unexpected rewrites.

    ABANDONED WORKING CODE

    This is code for an application that is abandoned because it works. Over time it’s forgotten and remains unattended. The day comes when the business needs new features or new OS changes and breaks the application.
     
    Example
    • A nightly batch process/program that has run well for many years. It copies critical application data to applications that require it. Over time, the IT organization has forgotten about this critical process.
    Cost
    • Uncertainty – Unknown dependencies.
    • Poor Estimates – Your customer/product tables might be updated by a nightly process that is long forgotten. Estimates and support roles forget to take this into account because it has always worked. Estimates cannot take into account processes it does not know about.
    • Unplanned Rewrite – Once discovered, support for abandoned code often requires a complete rewrite. Only then can new features can be added or the application be considered supported. Rewrites occur when a code base is so out of date it cannot be cost effectively refactored.
    Solution
    • The Mashup attempts to combine applications using a single core. Even in cases where an application requires little attention, its core components are kept up to date. As new techniques are adopted, linters are used to identify code that needs updating, even in unattended code. The application remains updated, visible, and not forgotten.

    DEVICE DEPENDENCE

    Device dependence forces the business into dependency on a device platform as a result of writing hardware platform specific applications.

    Example
    • An IT department writes a series of mobile applications for iOS because, at the time of writing code, all corporate phones were iPhones. At some point the business is offered a significant savings on the Android platform but this becomes a lost opportunity because of the iOS hardware dependency.
    Cost
    • The cost of smartphones and tablets varies as competition increases. A vendor offering can easily cut a company’s smartphone devices in half. This can be a significant lost opportunity because of decisions made by the IT department.
    Solution
    • Don’t lock your company into a hardware platform. Use the Mashup, Angular, Bootstrap, Ionic, and WebApi to create platform independent applications.

    FEAR OF BREAKING INTERFACES

    Interfaces allow components to be consumed by other components and applications to talk to other applications. Rather than change an existing interface that might be consumed by another component or application, the approach has been to bolt on additional code.

    Example
    • A component, representing Customer, is being used by multiple applications within an organization. After merging with another company, the definition of Customer has changed. Rather than alter the Customer to reflect the new reality, the old reality of Customer is maintained while also supporting a new reality of Customer.
    • Another example of the fear of breaking interfaces is the web browser, Internet Explorer. Microsoft held fast to its commitment to supporting businesses that created applications based on the Internet Explorer platform.
    • Over time, code that has been bolted onto becomes brittle and easily broken and then it becomes the “Avoided Code.”
    Cost
    • Complexity – The increased complexity and, often, harder to read code increases the cost of ownership for the system.
    • Internet Explorer – The IE6 browser became famous for being slow and not keeping with the times. Nearly all vendors have dropped Internet Explorer through version 9 as a result. Microsoft is even abandoning Internet Explorer in favor of their new browser, “Spartan,” which holds no allegiance to past applications.
    Solution
    • Abandon the philosophy of protecting existing interfaces. Break every interface that does not reflect the current reality. This can only be done softly by adoption of a DevOps build process with Continuous Delivery. The Mashup, because of Angular, is uniquely suited for testability within a build process.

    NO TECHNICAL LEADERSHIP

    Lack of technical leadership will create the scenario where too many technologies exist to support. As a result, team knowledge becomes shallow and developers become paralyzed. Without leadership, a team cannot decide where to spend its most precious resource, time.

    Example
    • Front-end development stack – So many options exist for front end development that organizations without strong technical leadership become paralyzed and learning stops.
    Cost
    • Lost Talent – Talented developer(s) desire strong leadership so they have confidence their hard work is not wasted. Talent will also not allow a corporation to handicap them in the job market.
    • Dated teams – Teams become dated because there are too many choices and no guidance.
    Solution
    • The Mashup helps ease the friction of learning the technologies to build modern web applications. The Mashup Core abstracts much of the complexity of Angular and other micro libraries, making SPA programming easy to learn. As skills increase, developers can contribute in more advanced and complex ways.

    MashupJS Philosophies

    http://robertdunaway.github.io
    http://mashupjs.github.io
     
    The Mashup is a learning tool that also serves as a bootstrap project for line-of-business applications.

    MashupJS Philosophies

    Reduce technical debt

    All effort must be made to reduce technical debt. We’re building business applications so we must consider cost before all else. The complete cost of ownership including initial development, support, and opportunity costs must be taken into account. Technical debt can be significantly reduced by making sound decisions based on past experiences.

    Below are a few items for reducing technical debt but the list could go on forever.
    • Reduce the number of technologies in the ecosystem.
    • Utilize strong technical leadership that gives direction.
    • Develop a strong DevOps component to the development process.
    • Adopt Continuous Integration and Continuous Deployment.
    • Resist version divergence

    Mobile First

    Whether or not you are designing specifically for mobile, the mobile first approach offers many benefits. When considering the real-estate available for mobile devices, you fall into the lap of success with better imagined UI design and faster running applications. When considering mobile, every aspect of performance from render time to the bits on the network is considered.

    Ultimately, it’s far easier to scale the UI up from mobile to desktop than to scale an applications UI down from the desktop.

    http://designshack.net/articles/css/mobilefirst/

    http://code.tutsplus.com/tutorials/mobile-first-with-bootstrap-3–net-34808

    (RWD) Responsive Web Design

    Responsive design is critical to delivering applications with a single code base because it takes in all form factors.

    http://responsivedesign.is/

    https://msdn.microsoft.com/en-us/magazine/hh653584.aspx

    http://www.smashingmagazine.com/2011/01/12/guidelines-for-responsive-web-design/

    http://en.wikipedia.org/wiki/Responsive_web_design

    Offline First

    Designing your application to be offline first makes the application more resilient in the face of network instability. Both desktop and web applications benefit from offline first design.

    https://developer.chrome.com/apps/offline_apps

    https://github.com/pazguille/offline-first

    http://jakearchibald.com/2014/offline-cookbook/

    Continuous Integration

    Continuous Integration is similar to build first. In a corporate environment, all your shared code is built often. The end result is you no longer have to fear breaking interfaces. Other applications that rely on your shared code will break during the nightly build. Fear of breaking interfaces leads to technical debt and eventually a complete re-write. Internet Explorer is a good case study for what happens when you fear breaking interfaces.

    https://www.youtube.com/watch?v=4sANX9AhM8c

    http://www.thoughtworks.com/continuous-integration

    Continuous Delivery

    DevOps is an emerging approach designed to reduce friction between the developer and operations processes. Continuous delivery to production also reduces risk because many smaller changes are less risky than fewer but larger changes. This approach leads to automation, removing the human element, resulting in further reduced risk.

    https://www.youtube.com/watch?v=McTZtyb9M38

    https://yow.eventer.com/events/1004/talks/1062

    http://www.thoughtworks.com/insights/blog/enabling-continuous-delivery-enterprises-testing

    https://www.youtube.com/watch?v=ZLBhVEo1OG4

    http://www.jamesshore.com/Blog/Continuous-Integration-on-a-Dollar-a-Day.html

    Interesting list of Philosophies

    The Mashup doesn’t subscribe to all of these but they all have something interesting to learn.

    http://en.wikipedia.org/wiki/List_of_software_development_philosophies