To react, or not to react: Patterns of reaction to API deprecation

被引:18
作者
Sawant, Anand Ashok [1 ]
Robbes, Romain [2 ]
Bacchelli, Alberto [3 ]
机构
[1] Delft Univ Technol, Software Engn Res Grp, Delft, Netherlands
[2] Free Univ Bozen Bolz, Software & Syst Engn Res Grp, Bozen Bolzano, Italy
[3] Univ Zurich, Dept Informat, Zurich, Switzerland
关键词
Deprecation; Application programming interface; API usage; !text type='Java']Java[!/text; SOCIAL DESIRABILITY; SUPPORT; BIAS;
D O I
10.1007/s10664-019-09713-w
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Application Programming Interfaces (API) provide reusable functionality to aid developers in the development process. The features provided by these APIs might change over time as the API evolves. To allow API consumers to peacefully transition from older obsolete features to new features, API producers make use of the deprecation mechanism that allows them to indicate to the consumer that a feature should no longer be used. The Java language designers noticed that no one was taking these deprecation warnings seriously and continued using outdated features. Due to this, they decided to change the implementation of this feature in Java 9. We question as to what extent this issue exists and whether the Java language designers have a case. We start by identifying the various ways in which an API consumer can react to deprecation. Following this we benchmark the frequency of the reaction patterns by creating a dataset consisting of data mined from 50 API consumers totalling 297,254 GitHub based projects and 1,322,612,567 type-checked method invocations. We see that predominantly consumers do not react to deprecation and we try to explain this behavior by surveying API consumers and by analyzing if the API's deprecation policy has an impact on the consumers' decision to react.
引用
收藏
页码:3824 / 3870
页数:47
相关论文
共 62 条
  • [41] Marks S., 2017, JEP 277 ENHANCED DEP
  • [42] An Empirical Study of API Stability and Adoption in the Android Ecosystem
    McDonnell, Tyler
    Ray, Baishakhi
    Kim, Miryung
    [J]. 2013 29TH IEEE INTERNATIONAL CONFERENCE ON SOFTWARE MAINTENANCE (ICSM), 2013, : 70 - 79
  • [43] Perkins Jeff H., 2005, PASTE 05, P111, DOI [10.1145/1108792.1108818, DOI 10.1145/1108768.1108818]
  • [44] Semantic versioning and impact of breaking changes in the Maven repository
    Raemaekers, S.
    van Deursen, A.
    Visser, J.
    [J]. JOURNAL OF SYSTEMS AND SOFTWARE, 2017, 129 : 140 - 158
  • [45] Raemaekers S, 2014, 14 IEEE INT WORK C S
  • [46] Raemaekers S, 2012, 2012 28TH IEEE INTERNATIONAL CONFERENCE ON SOFTWARE MAINTENANCE (ICSM), P378, DOI 10.1109/ICSM.2012.6405296
  • [47] Rose JR, 2017, DEPRECATE APIS
  • [48] Savga Ilie, 2007, P 6 INT C GEN PROGR, P175
  • [49] Sawant A. A., 2017, EMPIR SOFTW ENG, P1
  • [50] Sawant AA, 2018, P 34 IEEE INT C SOFT