CALL US

  +91 8266041801

  +44 203 372 4609

  +1 408 454 6110

  evontech

Get Free Quote

Rewriting the code from scratch for a software product - A bad decision

As part of our software development services, we are involved in maintenance and enhancement for software products for our clients. At times, these clients want to explore the option of rewriting the application on some latest technology. Quite often the technical team is also keen on rewriting the application on the latest technology, rather than digging into the existing code base for providing bug fixes or adding new features. While it may be appear to be an attractive option for the development team to sell the idea of development from scratch on the latest technology, there are a few misconceptions and high risks normally associated with the 'rewrite to fix everything' approach:

- Rewriting the code will take less time than fixing the issues: Software development projects nearly always take more time than initially planned. The bigger the project, higher are the chances for it to have cost and time overruns. You may well end up adding many new bugs into the system and having to incur cost of many test and bug fixing cycles before having a product which can be released.

- Existing code base is messy: As the software tends to evolve over time, the existing code base is likely to be messy, and is likely to appear messier to a developer who has not been involved in the initial development. Even with a rewrite, it is very likely that the new code will end up being as messy as your current code by the time development is completed.

- New Architecture and Framework will address all the current issues: It is not easy to define an architectural framework, which can handle all changes and enhancements, which may come in the future and still withstand the test of time in terms of maintainability, scalability and performance. What are the chances, that the same or new mistakes will not be made in the new approach and you do not end up facing the same or some more serious problems?

- Cutting Edge Technology: You may start the rewrite on a technology  which is seen on the day as cutting edge, but by the time you complete the development it may not longer be seen as the in thing. Also your current code base is very likely on a well established technology with a wide support base, which is not likely to be the case with the so called cool and latest technology.

Some other high risks associated with the rewrite approach are:

- High Risk of failure - There is a high risk after starting the rewrite you run into serious issues which lead to abandoning the project. This is more harmful in the scenario when your existing product with a customer base has been neglected over this time period as you have moved resources for the new development.

- Missing existing features and workflows - While rewriting the code there is a high risk that you will miss some features and workflows of the existing product. You can be sure it is this feature your customer base will miss the most after release.

The most important reason for your product to exist and have a wide customer base is because it solves a customer problem and makes their life easier. This should always be kept in mind while defining the development roadmap for your product. Any decisions of change in technology or platform should be made with this goal in mind. 

The best approach for any technology migration for your product should be planned in a gradual and iterative manner. Some key points which should be part of your strategy are:

- Re-factor the existing code base. Take up parts of the existing code base to re-factor, add useful comments, test and release.
  The key word here is Re-factor.  This is the least risky option.
- Identify modules or components which can to rewritten and migrated to a new technology with the least effort and risk. This will give you insight on the technology and also validate your approach.
- Develop the core parts of your product on the new technology as a parallel development without affecting the support and evolution for the existing product.
- Your customers may want some new features on your existing product. It is a good idea to release this on the existing product and get valuable customer feedback rather than promising the customer and keep them waiting for the release of the new version.
- Be aware of the end-of-life announcements regarding the technology you are currently using. Plan the migration to a new technology based on this timeline so that you are not rushed into it.

If you take up the porting of your product to a new technology with the above approach and take steps to mitigate the risks, while ensuring that the support to the existing customer and their needs are not compromised, you are more likely to succeed.

Recruitment Process Outsourcing Explained
Consulting - First step to Outsourced Product Deve...

Comments

 
No comments yet
Already Registered? Login Here
Guest
Wednesday, 08 April 2020
If you'd like to register, please fill in the username, password and name fields.

SEARCH BLOG

Cloud computing Big Data IT developers IT consulting and software development Web development Big Data Analytics Project Management Salesforce customization outsourcing Javascript App development Offshore development India Salesforce consulting Software development Software development and testing Product Development Salesforce Cloud Services Salesforce CRM Salesforce Mobile Development Start-ups Salesforce Lightning Offshore software development business analysts Node.js Salesforce development Agile product Development Web app development data security Agile Development project management methodology EmployeeEngagement Offshore software development services Evon Technologies Offshore software development company risk management Digital Marketing Artificial intelligence Reactive Programming JUnit Salesforce ISV QA and Testing Android apps Mobile app development Data security breach Collaboration salesforce implementation AI in mobile apps AppExchange DevOps services React.js Business continuity Web designinng Real time data React Native Salesforce Scrum Project Manager business management Java development tools Business Growth data protection Python salesforce apps Big Data Cloud Database & Computing | EPLcricket GDPR Social Media Marketing QA services Recreationalactivity PHP development Resource Management Staff Augmentation Higher Productivity Salesforce cloud Virtual reality marketing automation Android development MVP Development Findnerd Salesforce AppExchange Recruitment Process Outsourcing What to learn after HTML CSS and Javascript Flask firewalls Google Allo App monetization Growth Hacking Einstein Analytics Cloud Public Cloud Techteam business accomplishments Apache Spark Product/Market Fit Top JavaScript Libraries disaster recovery Website Management Javascript platform Cloud Management Tool JavaServer Pages HTML tricks for WordPress

About Us

Evon is one of the top software development consulting companies based in India. We are a 250+ people company. We primarily service clients who want to either completely outsource a new idea or are looking to build an offshore team.

GoodFirms Badge

Recent Tweets

Evon Technologies

What are the #security and privacy implications of building #Salesforce apps? Here is a guide to prepare yourself f… https://t.co/IpInYsOMNo

Evon Technologies

Researchers at @GoodFirms Recognize Evon Technologies as an Unyielding Technology Partner, Read here -… https://t.co/q5516b71Vy

Get in Touch

  +91 8266041801

  +44 203 372 4609

  +1 408 454 6110

  evontech

 This email address is being protected from spambots. You need JavaScript enabled to view it.

   A- 5, IT Park, Dehradun, Uttarakhand, India, PIN - 248001.

follow us on

×
We use cookies on our website to provide you with a more personalised digital experience and for analytics related to our website and other media. For more information, please review our Privacy Policy and Cookies Policy.