Application discovery and understanding (ADU) is the process of automatically analyzing artifacts of a software application and determining metadata structures associated with the application in the form of lists of data elements and business rules. The relationships discovered between this application and a central metadata registry is then stored in the metadata registry itself.
On average, developers are spending only 5% of their time writing new code, 20% modifying the legacy code and up to 60% understanding the existing code.[1] Thus, ADU saves a great deal of time and expense for organizations that are involved in the change control and impact analysis of complex computer systems. Impact analysis allows managers to know that if specific structures are changed or removed altogether, what the impact of those changes might be to enterprise-wide systems. This process has been largely used in the preparation of Y2K changes and validations in software.[2]
Application Discovery and Understanding is part of the process enabling development teams to learn and improve themselves by providing information on the context and current state of the application.[3]
The process of gaining application understanding is greatly accelerated when the extracted metadata is displayed using interactive diagrams.[4]
When a developer can browse the metadata, and drill down into relevant details on demand, then application understanding is achieved in a way that is natural to the developer.[5] Significant reductions in the effort and time required to perform full impact analysis have been reported when ADU tools are implemented.[6] ADU tools are especially beneficial to newly hired developers. A newly hired developer will be productive much sooner and will require less assistance from the existing staff when ADU tools are in place.
ADU software is usually written to scan the following application structures:
The output of the ADU process frequently includes:
Note that a registered data element is any data element that already exists within a metadata registry.