This invention relates to a computer program product and method for extracting UML models from legacy applications. More specifically, the invention relates to a method and product for extracting and enhancing a UML model from a legacy application, based on an existing repository containing all necessary information about the legacy application.
In modern application development, it is desirable to capture the requirements, functionality and implementation details of an application in the form of design models. One such design model, which is commonly used, is known as the Unified Modeling Language, i.e., UML, which provides a standard which allows for the use of a variety of commercial tools to allow communication between parties.
For purposes of this description, it is noted that the Unified Modeling Language (UML) is a well-known nonproprietary, object modeling and specification language used in software engineering. UML is a general purpose modeling language that includes a standardized graphical notation that may be used to create an abstract model of a system which is typically known as the UML model.
In modern application development, UML is primarily used for developing new applications. However, up to now, UML tools have not been used to describe what are known generally as legacy applications which have been designed and built with older technologies.
Using UML is desirable for new or more modem applications for a number of reasons. First, UML is generally accepted as a language, and any UML description of an application is easy to share between development teams. There are also many commercially available software tools which are capable of forward engineering UML models into program code, all done in a conventional manner as will be readily apparent to those of ordinary skill in the art. Modem day UML tools such as Rational Rose, Together, Sparx, etc. are useful for reverse engineering applications by extracting UML from code in modem languages like Java. However, there are no such tools offering the same reverse engineering capability for use with legacy applications.
By the term legacy applications is meant applications developed with technologies beginning in the 1960s to date. Such legacy applications have been written in languages such as COBOL, PLI, Natural and RPG. Such applications also include databases such as VSAM, ADABAS, IMSIDB, IDMS, and DMS. Other legacy applications include environments such as CICS, IMSIDC. Most of such applications were developed prior to the development of UML.
Accordingly, although not completely useful when employed with legacy applications because of the design of current UML tools for use with modem applications, the problems of the use of existing UML tools with older applications is overcome in accordance with the invention in which there is provided a method and system of using UML tools to generate a UML diagram for legacy applications
Accordingly, in accordance with the invention there is provided a method of extracting UML models from a legacy application. It is assumed that there has already been created a repository of all objects and information about the objects contained in the legacy application. It is also assumed that the repository also contains a collection of business rules implemented in the application. For each legacy application object and for each business rule, the repository keeps pointers to the legacy artifacts or code where they are implemented (such as programs, screens, tables or transactions). Such repositories describing legacy applications may be created using existing legacy analysis commercial tools, as for instance Relativity Modernization Workbench. It is further assumed that the repository is accessible to the system described by this invention through a specialized library of programs, usually called an API (“application public interface”). This interface would allow the system described by the invention to access facts about the legacy application, in particular the association between screens and programs and the transitions or calls between the programs. Such information may be used to create the so-called “screen flows,” which indicate the order in which the screens are navigated by the application user in order to perform a particular task. Once a UML diagram describing the legacy application is created by processing the repository, UML objects in the UML diagram are linked either automatically or manually to the legacy objects and in particular to the business rules which have been extracted from the legacy application, thus creating an enhanced UML model.
In a more specific aspect, this invention involves the creation of two types of UML diagrams: Use Case diagrams and Activity diagrams. For purposes of describing the invention, the following definitions are provided.
Activity diagram: Activity diagrams are diagrams are used to model the behaviors of a system and the way in which the behaviors are related in an overall flow of the system. Activity diagrams show the logical paths a process follows based on various conditions, concurrent processing, data access, interruptions and other logical path distinctions which are all used to construct a process, system or procedure.
Activity: An activity organizes and specifies the participation of subordinate behavior's, such as sub-activities or actions, to retlect the control and data flow of a process. Activities are used for a number of modeling purposes, from procedural-type application development for system design, to business process modeling of organizational structures or workflow.
Use Case diagram: A Use Case diagram captures use cases and actor interactions. It describes the functional requirements of a system, the manner that outside things (actors) interact at the system boundary, and the response of the system.
Use Case: A Use Case is a UML modeling element that describes how a user of the proposed system will interact with the system to perform a discreet unit of work. It describes and signifies a single interaction over time that has meaning for the end user (person, machine, or other system), and is required to leave the system in a complete state, either with the interaction completed or rolled back to its initial state.
Business Rule: Business rules describe the operations, definitions and constraints that apply to an organization in achieving its goals. They mey be implemented in the code of a computer application serving the organization. In the case of an existing legacy application, business rules may be collected. One example of how such business rules may be collected is described in U.S. patent application Ser. No. 10/827,953, the disclosure of which is incorporated by reference in its entirety.
In a yet more specific aspect, method involves creating Use Case diagrams from a hierarchy of screens of the legacy application. An Activity diagram is created based on a flow of screens and procedures of the legacy application.
In the case of the hierarchy of screens, it comprises a tree format starting with the main menu screen and subsequent flows to other screens. The Use Cases are designated by pointing to selected screens and creating a Use Case for each selected screen in a manner in which, if a selected screen is subordinate to another selected screen, then its Use Case either extends or is included in the Use Case derived from the screen to which it is subordinate.
Yet still further the UML diagrams and UML objects from the legacy application can be manually modified to describe additional information not automatically extracted with the UML mining tool. In a yet still a more specific aspect, the UML diagrams and objects are created in a manner in which they can be exported to and imported from another UML tool through XMI. The enhanced UML model results in part from attaching business rules extracted from the legacy program to the UML model created with the UML mining tool to result in the enhanced model.
In a yet still further aspect, the invention relates to a computer program product configured for achieving the foregoing. The product is encoded on storage media such as CD, hard drive, USB flash drive, etc. and others as will be readily apparent to those of ordinary skill. It is operable on a computer with screens and other peripherals, as will be readily apparent to those of ordinary skill.
The program is designed for accessing a repository of all objects and information about the objects which are contained in a legacy application. The program functions to create a UML model of the legacy application by processing the repository. A further function allows linking of UML objects in the UML model to business rules and specifying of additional details about the UML objects, including at least information about the legacy objects and where they were derived.
Having thus briefly described the invention, the same will become more clearly evident from the following detailed discussion of the drawing wherein:
In understanding the invention, it is important to appreciate that there are two major functionality aspects of high interest in analyzing a legacy application. The two functionality aspects are a UML model of the legacy application and the business rules embodied in the legacy application. With respect to extracting business rules, reference is made to copending application Ser. No. 10/827,953 filed Apr. 20, 2004 of the same inventor herein. UML, was previously discussed and is well known, and describes the requirements, functionality in terms of processes, structural aspects and implementation of the application. Business rules describe the fundamental restrictions on how the company or organization acts, irrespective of implementation.
This is an example of what kind of functionality is described in an UML model and what kind of functionality is described in business rules. A UML model may describe, for example, how to create an insurance policy by adding information about the customer and the car, in a specific number of steps. The business rules are concerned with the calculation of the premium or the criteria for accepting a particular customer.
In the past, the two aspects, i.e., UML and business rules were managed by separate technologies such as the previously described modem UML tools or business rules engines as noted with reference to the copending patent application. In accordance with the invention the two are brought together so that one analyzing an application can determine that a specific business rule is invoked during a particular process, which process is defined by the UML model. Thus, in accordance with the invention, some UML objects are able to automatically or manually be linked to business rules.
In considering how to implement the invention, it is important to understand that there may already exist a high level UML description of the application, for example, in another UML tool. In accordance with the invention, it is important to enrich the existing model by uncovering new details in the current implementation in code, or creating links for references between objects and implementation artifacts. In accordance with the invention, the UML can be extracted by the system of the invention and then exported to another UML tool, or it can also be implemented by first developing the UML model in another UML tool and then importing it into the system of the invention for later enrichment in linkage to legacy code for later reexporting. This is done, in one aspect, by a computer program product as previously described wherein the product is on storage media and functions through a computer as further described herein.
In one embodiment, a legacy repository has already been created in a manner well known to those of ordinary skill in the art. The legacy repository contains information collected by parsing the sources of a legacy application. The repository includes an inventory of all objects in the application, such as sources, programs, files, tables and screens. Information about the internals of such objects is also contained in the repository such as variable used in the program or the fields which appear on a screen.
Tools for creating such a repository are available commercially, for example, from Relativity Technologies, Inc. under the name RMW, and the invention involves in part interpreting the information in such a repository.
Accordingly, in a general aspect as shown
After a UML model is created, a mining tool export facility 111 is applied to the model to create XMI files 113 which are then processed through a UML modeling tool to result in a refined UML model 117.
Stated more broadly as shown in
While a number of UML diagram types may be extracted or built based on a legacy application, the invention is particularly concerned with the extraction of two types of diagrams which have been previously discussed: Use Case diagram and Activity diagram.
As shown in
In implementing the system and method, when a UML object is derived from an application artifact, the system stores and maintains a pointer to the corresponding this artifact. This allows the system user to explore derived UML diagrams and with a simple click, automatically open a window which shows the legacy objects corresponding to a UML object and even see appropriate code inside a program. This allows the user to view not only the derived diagrams and objects, but where and how they are implemented in the legacy application.
To extract a Use Case diagram, the user starts by creating a new and empty Use Case diagram, as shown in
The user then picks a screen from the screen hierarchy and indicates that a use case is to be created from it. This is done by either dragging the screen object from the screen hierarchy window and dropping it in the Use Case diagram window, or from a pop up menu shown when the user right clicks on a screen. A use case object automatically appears having the same name as the business name of the screen as shown in
To extract an Activity diagram, the user starts by creating a new Activity diagram. Initially, this diagrams contains just the “initial” and “final” objects, as shown in
By way of example, a screen diagram may be constructed automatically as follows. If a screen A is received by a program A, which then passes exclusive control to program B when an event E is intercepted, and program B sends screen B, then the nodes “screen A”-“event E” screen B″ are automatically constructed as shown in
Once all UML objects and diagrams are derived, the business rules which were also separately identified in the application may be connected to the UML objects either automatically or manually. As each derived UML object has a pointer to the code showing the program code where it is implemented and each business rule has a pointer to the code showing where the rule is implemented, the system may connect the business rule to the UML object if the code pointed by the business rule intersects the code pointed by the UML object. Thus, the system user may see which business rules are applied in the performance of a particular activity.
Based on the foregoing description it will be apparent to one of ordinary skill how to program a system such as a computer to result in the methodology described as implemented through the screen shots illustrated herein. In addition, having thus generally described the invention, the same will become better understood from the appended claims from in which it is described in a non-limiting manner.
This application is a continuation of U.S. patent application Ser. No. 11/649,134, filed on Jan. 3, 2007 (Attorney Docket No.: MIC-149), entitled “System and Method for Extracting UML Models from Legacy Applications,” which is hereby incorporated by reference in its entirety for all purposes.
Number | Date | Country | |
---|---|---|---|
Parent | 11649134 | Jan 2007 | US |
Child | 13298268 | US |