Abstract
Deciding what constitutes a single module, what classes belong to which module or the right set of modules for a specific software system has always been a challenging task. The problem is even harder in large-scale software systems composed of thousands of classes and hundreds of modules. Over the years, researchers have been proposing different techniques to support developers in re-modularizing their software systems. In particular, the search-based software re-modularization is an active research topic within the software engineering community for more than 20 years.
This paper describes our efforts in applying search-based software re-modularization approaches at Adyen, a large-scale payment company. Adyen's code base has 5.5M+ lines of code, split into around 70 different modules. We leveraged the existing body of knowledge in the field to devise our own search algorithm and applied it to our code base. Our results show that search-based approaches scale to large code bases as ours. Our algorithm can find solutions that improve the code base according to the metrics we optimize for, and developers see value in the recommendations. Based on our experiences, we then list a set of challenges and opportunities for future researchers, aiming at making search-based software re-modularization more efficient for large-scale software companies.
This paper describes our efforts in applying search-based software re-modularization approaches at Adyen, a large-scale payment company. Adyen's code base has 5.5M+ lines of code, split into around 70 different modules. We leveraged the existing body of knowledge in the field to devise our own search algorithm and applied it to our code base. Our results show that search-based approaches scale to large code bases as ours. Our algorithm can find solutions that improve the code base according to the metrics we optimize for, and developers see value in the recommendations. Based on our experiences, we then list a set of challenges and opportunities for future researchers, aiming at making search-based software re-modularization more efficient for large-scale software companies.
Original language | English |
---|---|
Title of host publication | 43rd International Conference on Software Engineering |
Subtitle of host publication | SEIP - Software Engineering in Practice |
Editors | L. O'Conner |
Place of Publication | Piscataway |
Publisher | IEEE |
Pages | 81-90 |
Number of pages | 10 |
ISBN (Print) | 978-1-6654-3869-8 |
DOIs | |
Publication status | Published - 2021 |
Event | 43rd International Conference on Software Engineering: SEIP - Software Engineering in Practice - Virtual at Madrid, Spain Duration: 23 May 2021 → 29 May 2021 |
Conference
Conference | 43rd International Conference on Software Engineering |
---|---|
Abbreviated title | ICSE-SEIP-2021 |
Country/Territory | Spain |
City | Virtual at Madrid |
Period | 23/05/21 → 29/05/21 |
Bibliographical note
Accepted author manuscriptKeywords
- software engineering
- search-based software engineering
- software refactoring
- software modularization