An Exploratory Study of API Changes and Usages based on Apache and Eclipse Ecosystems. Wu, W., Khomh, F., , Adams, B., Guéhéneuc, Y., & Antoniol, G. Journal of Empirical Software Engineering (EMSE), 21(6):2366�2412, Springer, December, 2016. 47 pages.
Paper abstract bibtex Frameworks are widely used in modern software development to reduce development costs. They are accessed through their Application Programming Interfaces (APIs), which specify the contracts with client programs. When frameworks evolve, API backwardcompatibility cannot always be guaranteed and client programs must upgrade to use the new releases. Because framework upgrades are not cost-free, observing API changes and usages together at fine-grained levels is necessary to help developers understand, assess, and forecast the cost of each framework upgrade. Whereas previous work studied API changes in frameworks and API usages in client programs separately, we analyse and classify API changes and usages together in 22 framework releases from the Apache and Eclipse ecosystems and their client programs. We find that (1) missing classes and methods happen more often in frameworks and affect client programs more often than the other API change types do, (2) missing interfaces occur rarely in frameworks but affect client programs often, (3) framework APIs are used on average in 35% of client classes and interfaces, (4) most of such usages could be encapsulated locally and reduced in number, and (5) about 11% of APIs usages could cause ripple effects in client programs when these APIs change. Based on these findings, we provide suggestions for developers and researchers to reduce the impact of API evolution through language mechanisms and design strategies.
@ARTICLE{Wu15-EMSE-APIChangeEcosystems,
author = {Wei Wu and Foutse Khomh and and Bram Adams and Yann-Ga{\"e}l Gu{\'e}h{\'e}neuc and Giuliano Antoniol},
title = {An Exploratory Study of {API} Changes and Usages based on {A}pache and {E}clipse Ecosystems},
journal = {Journal of Empirical Software Engineering ({EMSE})},
year = {2016},
month = {December},
volume = {21},
number = {6},
pages = {2366�2412},
note = {47 pages.},
abstract = {Frameworks are widely used in modern software development to reduce development costs.
They are accessed through their Application Programming Interfaces (APIs), which specify the contracts
with client programs. When frameworks evolve, API backwardcompatibility cannot always be guaranteed and
client programs must upgrade to use the new releases. Because framework upgrades are not cost-free,
observing API changes and usages together at fine-grained levels is necessary to help developers
understand, assess, and forecast the cost of each framework upgrade. Whereas previous work studied API
changes in frameworks and API usages in client programs separately, we analyse and classify API changes
and usages together in 22 framework releases from the Apache and Eclipse ecosystems and their client
programs. We find that (1) missing classes and methods happen more often in frameworks and affect client
programs more often than the other API change types do, (2) missing interfaces occur rarely in frameworks
but affect client programs often, (3) framework APIs are used on average in 35\% of client classes and
interfaces, (4) most of such usages could be encapsulated locally and reduced in number, and (5) about
11\% of APIs usages could cause ripple effects in client programs when these APIs change. Based on these
findings, we provide suggestions for developers and researchers to reduce the impact of API evolution
through language mechanisms and design strategies.},
editor = {Lionel Briand and Thomas Zimmermann},
grant = {NSERC DG and CRC on Software Patterns},
keywords = {Understanding program comprehension ; EMSE},
kind = {RIAS},
language = {english},
publisher = {Springer},
url = {http://www.ptidej.net/publications/documents/EMSE16a.doc.pdf}
}
Downloads: 0
{"_id":"CkEceLpCdt6agyYsn","bibbaseid":"wu-khomh--adams-guhneuc-antoniol-anexploratorystudyofapichangesandusagesbasedonapacheandeclipseecosystems-2016","downloads":0,"creationDate":"2018-01-17T20:29:42.183Z","title":"An Exploratory Study of API Changes and Usages based on Apache and Eclipse Ecosystems","author_short":["Wu, W.","Khomh, F.","","Adams, B.","Guéhéneuc, Y.","Antoniol, G."],"year":2016,"bibtype":"article","biburl":"http://www.yann-gael.gueheneuc.net/Work/BibBase/guehene (automatically cleaned).bib","bibdata":{"bibtype":"article","type":"article","author":[{"firstnames":["Wei"],"propositions":[],"lastnames":["Wu"],"suffixes":[]},{"firstnames":["Foutse"],"propositions":[],"lastnames":["Khomh"],"suffixes":[]},{"firstnames":[],"propositions":[],"lastnames":[""],"suffixes":[]},{"firstnames":["Bram"],"propositions":[],"lastnames":["Adams"],"suffixes":[]},{"firstnames":["Yann-Gaël"],"propositions":[],"lastnames":["Guéhéneuc"],"suffixes":[]},{"firstnames":["Giuliano"],"propositions":[],"lastnames":["Antoniol"],"suffixes":[]}],"title":"An Exploratory Study of API Changes and Usages based on Apache and Eclipse Ecosystems","journal":"Journal of Empirical Software Engineering (EMSE)","year":"2016","month":"December","volume":"21","number":"6","pages":"2366�2412","note":"47 pages.","abstract":"Frameworks are widely used in modern software development to reduce development costs. They are accessed through their Application Programming Interfaces (APIs), which specify the contracts with client programs. When frameworks evolve, API backwardcompatibility cannot always be guaranteed and client programs must upgrade to use the new releases. Because framework upgrades are not cost-free, observing API changes and usages together at fine-grained levels is necessary to help developers understand, assess, and forecast the cost of each framework upgrade. Whereas previous work studied API changes in frameworks and API usages in client programs separately, we analyse and classify API changes and usages together in 22 framework releases from the Apache and Eclipse ecosystems and their client programs. We find that (1) missing classes and methods happen more often in frameworks and affect client programs more often than the other API change types do, (2) missing interfaces occur rarely in frameworks but affect client programs often, (3) framework APIs are used on average in 35% of client classes and interfaces, (4) most of such usages could be encapsulated locally and reduced in number, and (5) about 11% of APIs usages could cause ripple effects in client programs when these APIs change. Based on these findings, we provide suggestions for developers and researchers to reduce the impact of API evolution through language mechanisms and design strategies.","editor":[{"firstnames":["Lionel"],"propositions":[],"lastnames":["Briand"],"suffixes":[]},{"firstnames":["Thomas"],"propositions":[],"lastnames":["Zimmermann"],"suffixes":[]}],"grant":"NSERC DG and CRC on Software Patterns","keywords":"Understanding program comprehension ; EMSE","kind":"RIAS","language":"english","publisher":"Springer","url":"http://www.ptidej.net/publications/documents/EMSE16a.doc.pdf","bibtex":"@ARTICLE{Wu15-EMSE-APIChangeEcosystems,\n author = {Wei Wu and Foutse Khomh and and Bram Adams and Yann-Ga{\\\"e}l Gu{\\'e}h{\\'e}neuc and Giuliano Antoniol},\n title = {An Exploratory Study of {API} Changes and Usages based on {A}pache and {E}clipse Ecosystems},\n journal = {Journal of Empirical Software Engineering ({EMSE})},\n year = {2016},\n month = {December},\n volume = {21},\n number = {6},\n pages = {2366�2412},\n note = {47 pages.},\n abstract = {Frameworks are widely used in modern software development to reduce development costs.\nThey are accessed through their Application Programming Interfaces (APIs), which specify the contracts\nwith client programs. When frameworks evolve, API backwardcompatibility cannot always be guaranteed and\nclient programs must upgrade to use the new releases. Because framework upgrades are not cost-free,\nobserving API changes and usages together at fine-grained levels is necessary to help developers\nunderstand, assess, and forecast the cost of each framework upgrade. Whereas previous work studied API\nchanges in frameworks and API usages in client programs separately, we analyse and classify API changes\nand usages together in 22 framework releases from the Apache and Eclipse ecosystems and their client\nprograms. We find that (1) missing classes and methods happen more often in frameworks and affect client\nprograms more often than the other API change types do, (2) missing interfaces occur rarely in frameworks\nbut affect client programs often, (3) framework APIs are used on average in 35\\% of client classes and\ninterfaces, (4) most of such usages could be encapsulated locally and reduced in number, and (5) about\n11\\% of APIs usages could cause ripple effects in client programs when these APIs change. Based on these\nfindings, we provide suggestions for developers and researchers to reduce the impact of API evolution\nthrough language mechanisms and design strategies.},\n editor = {Lionel Briand and Thomas Zimmermann},\n grant = {NSERC DG and CRC on Software Patterns},\n keywords = {Understanding program comprehension ; EMSE},\n kind = {RIAS},\n language = {english},\n publisher = {Springer},\n url = {http://www.ptidej.net/publications/documents/EMSE16a.doc.pdf}\n}\n\n","author_short":["Wu, W.","Khomh, F.","","Adams, B.","Guéhéneuc, Y.","Antoniol, G."],"editor_short":["Briand, L.","Zimmermann, T."],"key":"Wu15-EMSE-APIChangeEcosystems","id":"Wu15-EMSE-APIChangeEcosystems","bibbaseid":"wu-khomh--adams-guhneuc-antoniol-anexploratorystudyofapichangesandusagesbasedonapacheandeclipseecosystems-2016","role":"author","urls":{"Paper":"http://www.ptidej.net/publications/documents/EMSE16a.doc.pdf"},"keyword":["Understanding program comprehension ; EMSE"],"metadata":{"authorlinks":{"guéhéneuc, y":"https://bibbase.org/show?bib=http://www.yann-gael.gueheneuc.net/Work/BibBase/guehene%20(automatically%20cleaned).bib"}},"downloads":0,"html":""},"search_terms":["exploratory","study","api","changes","usages","based","apache","eclipse","ecosystems","wu","khomh","","adams","guéhéneuc","antoniol"],"keywords":["understanding program comprehension ; emse"],"authorIDs":["xkviMnkrGBneANvMr"],"dataSources":["Sed98LbBeGaXxenrM"]}