The present application claims priority to Indian Patent Application No. 201841000981, filed Jan. 9, 2018. The entirety of the above application is expressly incorporated herein by reference.
Embodiments of the present disclosure relate to devices and associated methods for transforming legacy application sources to modern languages, and more specifically, but not limited to, a system and method for transforming legacy applications and enabling them to deploy and execute on modern technology platforms, multi-tier architectures and distributed hardware.
The various technical divisions of an organization, irrespective of the domain, face several challenges with applications that are built and executing on legacy or obsolete technology platforms and hardware infrastructure. Such legacy technology platforms include but not limited to Visual Basic, Mainframe/COBOL (Common Business Oriented Language), PowerBuilder, OracleForms, HPS, Delphi, FoxPro, ProC etc. running on single central processing unit (CPU) with limited processing capacity, memory storage and networking interfaces.
The Information Technology Systems that are developed specially for a particular organisation have a long lifetime. Many such systems that are still in use were developed many years ago using technologies that are now obsolete.
However, these systems are still critical and are essential for the normal functioning of the organization and are called legacy systems
The various challenges posed by this situation comprise:
Thus, there is a significant risk and cost involved in simply scrapping a legacy system and replacing it with a system that has been developed using modern technology as legacy systems rarely have a complete specification.
Also, during their lifetime legacy systems undergo many changes which are not always documented.
Thus, in order to remain useful, legacy systems need to be transformed into modernized systems.
Again, changing legacy systems is often expensive as:
The traditional solutions to overcome the above challenges with legacy technology platforms include:
The inventors of the present application have performed a comparative analysis of various existing solutions.
For example, the following table compares these solution options for transforming the legacy applications based on various parameters:
Embodiments of the present disclosure propose and transform the legacy applications with maximum optimization of at least above parameters.
For example, the Automated Technology Modernization Accelerator (ATMA) proposed by the present disclosure transforms legacy application sources to modern language and enables them deploy and execute on modern technology platform and multi-tier architecture, thus also improving non-functional qualities of the applications such as scalability, flexibility, modularity, extendibility, maintainability etc.
For purposes of summarizing, certain aspects, advantages and features of the disclosure have been described herein. It is to be understood that not necessarily all such advantages may be achieved in accordance with any one particular embodiment of the disclosure. Thus, the present disclosure may be embodied or carried out in a manner that achieves or optimizes one advantage or group of advantages as taught herein without necessarily achieving other advantages as may be taught suggested herein.
It is an object of the present disclosure to transform legacy application sources to modern languages.
It is an object of the present disclosure to deploy and execute erstwhile legacy application on modern technology platforms and multi-tier architectures.
It is an object of the present disclosure to rearrange the elements of legacy application into a syntax tree and capture the inter-dependencies among such elements.
It is an object of the present disclosure to distribute the elements of the legacy application into a cluster of processors (e.g., CPUs), memory units (e.g., random access memory (RAM)), file systems, storage devices, networks, switches, routers and/or load balancers.
An embodiment of the present disclosure may provide for a Code Quality Corrector to use code quality assessment rules and apply appropriate fixes to legacy application under processing.
It is an object of the present disclosure to assess the functional quality of the transformed application at development phase by providing test cases.
All the embodiments as herein described with respect to the present disclosure are applicable to disclosed methods and corresponding systems.
These and other embodiments of the present disclosure will also become readily apparent to those skilled in the art from the following detailed description of the embodiments having reference to the attached figures, the disclosure not being limited to any particular embodiments disclosed.
For a better understanding of the embodiments of the systems and methods described herein, and to show more clearly how they may be carried into effect, reference will now be made, by way of example, to the accompanying drawings.
Exemplary embodiments now will be described with reference to the accompanying drawings. The disclosure may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey its scope to those skilled in the art. The terminology used in the detailed description of the particular exemplary embodiments illustrated in the accompanying drawings is not intended to be limiting. In the drawings, like numbers refer to like elements.
The specification may refer to “an”, “one” or “some” embodiment(s) in several locations. This does not necessarily imply that each such reference is to the same embodiment(s), or that the feature only applies to a single embodiment. Single features of different embodiments may also be combined to provide other embodiments.
As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless expressly stated otherwise. It will be further understood that the terms “includes”, “comprises”, “including” and/or “comprising” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. It will be understood that when an element is referred to as being “connected” or “coupled” to another element, it can be directly connected or coupled to the other element or intervening elements may be present. Furthermore, “connected” or “coupled” as used herein may include operatively connected or coupled. As used herein, the term “and/or” includes any and all combinations and arrangements of one or more of the associated listed items.
Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art to which this disclosure pertains. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
The figures depict a simplified structure only showing some elements and functional entities, all being logical units whose implementation may differ from what is shown. The connections shown are logical connections; the actual physical connections may be different. It is apparent to a person skilled in the art that the structure may also comprise other functions and structures. It should be appreciated that the functions, structures, elements and the protocols used in communication are irrelevant to the present disclosure. Therefore, they need not be discussed in more detail here.
Also, all logical units described and depicted in the figures include the software and/or hardware components required for the unit to function. Further, each unit may comprise within itself one or more components which are implicitly understood. These components may be operatively coupled to each other and be configured to communicate with each other to perform the function of the said unit.
The term “legacy technology” can refer to applications, platforms, hardware setups, programming languages and other technologies that have been superseded by newer options.
A typical legacy application comprises elements such as one or more user interface (UI) controls, one or more controller components handling the user events performed on the controls and/or navigation of pages, one or more model components representing and/or holding the data, one or more service components implementing the business logic, processing logic, data access, data transformation or the like.
These elements are usually arranged in monolithic or client server architecture and are often all tightly coupled with each other, making the application difficult to scale, maintain and/or extend.
Such elements may include, but are not limited to
UI Control,
Model,
Service, and
Controller.
To identify such elements, an ATMA platform of the present disclosure may provide a comprehensive set of lexicons and pattern matching rules for each of the supported legacy programming languages to identify the above types of elements in the respective platforms.
After recognizing of the elements as identified above, ATMA AST Creator builds an element tree.
One of the major objectives for rearranging identified elements is to appropriately capture the inter-dependencies among such elements.
The ATMA platform of the present disclosure may implement a set of “Walker” components that are specialized to filter, decompose and decouple a specific type of the elements of the tree, together with the metadata and behavior of the elements.
Each walker component may be coupled with a respective generator component. The generator component may generate source code equivalent to that of the element that is filtered, along with all its characteristics, behavior and interactions.
The ATMA platform of the present disclosure may additionally comprise a component named “CQC (Code Quality Corrector)”, capable of automatically reducing the technical debt of the transformed code in target technology platform (e.g., Java in the example depicted in
The CQC of the present disclosure may execute static code quality analysis tools, such as Sonar or the like, to assess the technical code quality and obtain the list of code quality defects and/or violations.
In a test of one embodiment of the present disclosure, about 50% of such code quality defects were corrected by CQC without requiring any intervention to reduce the overall technical debt of the transformed application.
The CQC may have correction handlers for each type of the code quality assessment rules to apply appropriate fixes for the violations.
The UTGen component of the ATMA platform is capable of generating a comprehensive set of unit test scripts for the selected target component or package, which can be executed on Junit, TestNG or similar platforms to assess the functional quality of the transformed application at development phase itself, which may reduce the functional debt.
Thus, the UTGen may help to identify the prospective errors of the application to be transformed at the development phase itself.
In particular, UTGen may generate unit test cases for performing unit testing of any and/or all methods of a Java Component, as depicted in the example of
Accordingly, UTGen may generate a unit test method for each of the operations in the class being tested.
The generated code for each unit test case may include at least:
In addition, the unit test classes may be instrumented with appropriate annotations necessary to invoke the component being tested in its deployment context, such as an Enterprise JavaBeans (EJB) container, a Spring container or the like.
UTGen may also offer capability to generate an instrumentation template for mocking some of the dependent components for unit testing in isolated environment.
The ATGen may comprise a component of ATMA platform that is built to provide an improved approach to functional testing of the modernized applications.
The ATGen component may allow intuitive tests to be developed and executed. For example, test engineers may use this tool to develop and generate test cases for test scenarios based on hypertext markup language (HTML) source code taken from screens in the transformed applications.
The test scripts may be highly maintainable and reusable.
The present disclosure provides a robust ATMA platform to handle transformation of multiple legacy platforms including, but not limited to, PowerBuilder, Oracle Forms, Delphi, Visual Basic, HPS, COBOL, PL/SQL, TSQL, PL1, .NET/C#, Pro-C and FoxPro.
The proposed modernization engine of ATMA may significantly improve the productivity and quality of the migration and may be extendible to support transformation of many different legacy languages and supports multiple target platforms such as Java/JEE, .NET/C#, SFDC, HTML5/AngularJS or the like.
The Automated Technology Modernization Accelerator (ATMA) of the present disclosure may help in
The technical solution provided by the present disclosure offers flexibility to choose from multiple architectures, implementation frameworks, deployment containers etc.
The UTGen, CQC and ATGen as described above provide unique capabilities extending automation capabilities beyond a construction phase.
Unlike existing mere code conversion tools, embodiments of the present disclosure may provide for a comprehensive automation platform to achieve legacy modernization, handling both architecture and other non-functional characteristics.
The ATMA may significantly improve the productivity and quality of such modernization.
The ATMA may help to overcome the challenges associated with applications running on legacy technology platforms by:
Also, as the modernized applications may be adapted to open standards on modern platforms, no proprietary tools or frameworks will be required; hence, no vendor lock-in will ensue.
Also, as the modernized applications may conform to coding standards, embodiments of the present disclosure may result in fewer defects and may decrease the cost of providing quality due to minimal rework requirements.
The present disclosure may be economical to transform legacy applications as the ATMA may
Modern Architecture Enabling Business Innovation
High Quality and Consistency of Deliverables
Flexible and Extendible
More than ten customer projects have been executed using above mentioned ATMA approach and the actual efforts consumed for the transformation of the three applications were compared against the estimated efforts through re-engineering approach.
The effort for re-engineering approach were estimated based on industry standard benchmark data for function point estimation of scope and productivity for the respective technology platforms. The actual effort consumed by the tested ATMA solution approach are measured and compared against the estimated approach to derive the percentage of savings achieved through the tested ATMA approach.
The following table presents the metrics from three different modernization projects executed for customers for different combinations of source and target platforms:
Benchmark data used for the above estimation is below:
Number | Date | Country | Kind |
---|---|---|---|
201841000981 | Jan 2018 | IN | national |
Number | Name | Date | Kind |
---|---|---|---|
7467375 | Tondreau | Dec 2008 | B2 |
7672957 | Cotichini | Mar 2010 | B2 |
20020178290 | Coulthard | Nov 2002 | A1 |
20030226132 | Tondreau | Dec 2003 | A1 |
20040158820 | Moore | Aug 2004 | A1 |
20050039173 | Tondreau, Jr. | Feb 2005 | A1 |
20070067756 | Garza | Mar 2007 | A1 |
20150020051 | Rabinovitch | Jan 2015 | A1 |
Entry |
---|
Bassin et al., “Managing the Maintenance of Ported, Outsourced, and Legacy Software via Orthogonal Defect Classification,” IEEE, 2013, 9pg. (Year: 2013). |
Kontogiannis et al., “Code Migration Through Transformations: An Experience Report,” ACM, 1998, 13pg. (Year: 1998). |
Varma et al., “NextGen eXtreme Porting—Structured by Automation,” ACM, 2005, 7pg. (Year: 2005). |
Wang et al., “Reengineering Standalone C++ Legacy Systems into the J2EE Partition Distributed Environment,” 2006, ACM, 9pg. (Year: 2006). |
Valetto et al., “Using Process Technology to Control and Coordinate Software Adaptation,” IEEE, 2003, 11pg. (Year: 2003). |
Number | Date | Country | |
---|---|---|---|
20190212992 A1 | Jul 2019 | US |