1 Introduction.- 2 Context, Rules and Principles.- 3 Maintainability and Development.- 4 Architecture and Evolution.- 5 Ad-hoc Development.- 6 Disciplined Development.- 7 Re-Engineering and Reverse Engineering.- 8 Multi-faceted Loose Coupling.- 9 Monitoring and Logging.- 10 Scale of Deployment.
Ervin Varga has been in the software industry as a professional software engineer since 1994 and today is the owner of the software consulting company Expro I.T. Consulting and a technical advisor of Mainflux. In addition, he is an IEEE Software Engineering Certified Instructor, and an associate professor at the University of Novi Sad, Serbia. Ervin is also author of several books and scientific journal/conference papers and has contributed to the JUnitPerf framework.
Software maintenance work is often considered a dauntingly rigid activity – this book proves the opposite: it demands high levels of creativity and thinking outside the box. Highlighting the creative aspects of software maintenance and combining analytical and systems thinking in a holistic manner, the book motivates readers not to blithely follow the beaten tracks of “technical rationality”. It delivers the content in a pragmatic fashion using case studies which are woven into long running story lines.
The book is organized in four parts, which can be read in any order, except for the first chapter, which introduces software maintenance and evolution and presents a number of case studies of software failures. The “Introduction to Key Concepts” briefly introduces the major elements of software maintenance by highlighting various core concepts that are vital in order to see the forest for the trees. Each such concept is illustrated with a worked example. Next, the “Forward Engineering” part debunks the myth that being fast and successful during initial development is all that matters. To this end, two categories of forward engineering are considered: an inept initial project with a multitude of hard evolutionary phases and an effective initial project with multiple straightforward future increments. “Reengineering and Reverse Engineering” shows the difficulties of dealing with a typical legacy system, and tackles tasks such as retrofitting tests, documenting a system, restructuring a system to make it amenable for further improvements, etc. Lastly, the “DevOps” section focuses on the importance and benefits of crossing the development versus operation chasm and demonstrates how the DevOps paradigm can turn a loosely coupled design into a loosely deployable solution.
The book is a valuable resource for readers familiar with the Java programming language, and with a basic understanding and/or experience of software construction and testing. Packed with examples for every elaborated concept, it offers complementary material for existing courses and is useful for students and professionals alike.