Semantic versioning versus breaking changes

A study of the maven repository

Conference Paper (2014)
Author(s)

Steven Raemaekers (Software Improvement Group)

A. Van Van Deursen (TU Delft - Software Technology)

Joost Visser (Software Improvement Group)

Department
Software Technology
DOI related publication
https://doi.org/10.1109/SCAM.2014.30
More Info
expand_more
Publication Year
2014
Language
English
Department
Software Technology
Pages (from-to)
215-224
ISBN (electronic)
9780769553047

Abstract

For users of software libraries or public programming interfaces (APIs), backward compatibility is a desirable trait. Without compatibility, library users will face increased risk and cost when upgrading their dependencies. In this study, we investigate semantic versioning, a versioning scheme which provides strict rules on major versus minor and patch releases. We analyze seven years of library release history in Maven Central, and contrast version identifiers with actual incompatibilities. We find that around one third of all releases introduce at least one breaking change, and that this figure is the same for minor and major releases, indicating that version numbers do not provide developers with information in stability of interfaces. Additionally, we find that the adherence to semantic versioning principles has only marginally increased over time. We also investigate the use of deprecation tags and find out that methods get deleted without applying deprecated tags, and methods with deprecated tags are never deleted. We conclude the paper by arguing that the adherence to semantic versioning principles should increase because it provides users of an interface with a way to determine the amount of rework that is expected when upgrading to a new version.

No files available

Metadata only record. There are no files for this record.