In the modern retailing industry, many enterprise resource planning (ERP) systems are considered legacy software systems that have become too expensive to replace and too costly to re-engineer. Countering the need to maintain and extend the business value of these systems is the need to do so in the simplest, cheapest, and least risky manner available. There are a number of approaches used by software engineers to mitigate the negative impact of evolving a legacy systems, including leveraging service-oriented architecture to automate manual tasks previously performed by humans. A relatively recent approach in software engineering focuses upon implementing self-managing attributes, or “autonomic” behavior in software applications and systems of applications in order to reduce or eliminate the need for human monitoring and intervention. Entire systems can be autonomic or they can be hybrid systems that implement one or more autonomic components to communicate with external systems. In this paper, we describe a commercial development project in which a legacy multi-channel commerce enterprise resource planning system was extended with service-oriented architecture an autonomic control loop design to communicate with an external third-party security screening provider. The goal was to reduce the cost of the human labor necessary to screen an ever-increasing volume of orders and to reduce the potential for human error in the screening process. The solution automated what was previously an inefficient, incomplete, and potentially error-prone manual process by inserting a new autonomic software component into the existing order fulfillment workflow.
[1]
Mary Shaw,et al.
Engineering Self-Adaptive Systems through Feedback Loops
,
2009,
Software Engineering for Self-Adaptive Systems.
[2]
Franco Zambonelli,et al.
A survey of autonomic communications
,
2006,
TAAS.
[3]
Jeffrey O. Kephart,et al.
The Vision of Autonomic Computing
,
2003,
Computer.
[4]
Shihong Huang,et al.
Software Reuse in the Evolution of an E-Commerce System: A Case Study
,
2010
.
[5]
Shihong Huang,et al.
Autonomic Software Systems: Developing for Self-Managing Legacy Systems
,
2014,
2014 IEEE International Conference on Software Maintenance and Evolution.
[6]
M.M. Lehman,et al.
Programs, life cycles, and laws of software evolution
,
1980,
Proceedings of the IEEE.
[7]
Shihong Huang,et al.
Leveraging service-oriented architecture to extend a legacy commerce system
,
2010,
2010 IEEE International Systems Conference.
[8]
Ladan Tahvildari,et al.
Self-adaptive software: Landscape and research challenges
,
2009,
TAAS.
[9]
Peyman Oreizy,et al.
An architecture-based approach to self-adaptive software
,
1999,
IEEE Intell. Syst..