Apache Subversion 1.15 Release Notes

This is work in progress. Subversion 1.15 has not been released yet.

What's New in Apache Subversion 1.15

Apache Subversion 1.15 is a superset of all previous Subversion releases, and is as of the time of its release considered the current "best" release. Any feature or bugfix in 1.0.x through 1.14.x is also in 1.15, but 1.15 contains features and bugfixes not present in any earlier release.

This page describes only major changes. For a complete list of changes, see the 1.15 section of the CHANGES file.

Compatibility Concerns

Older clients and servers interoperate transparently with 1.15 servers and clients. However, some of the new 1.15 features may not be available unless both client and server are the latest version. There are also cases where a new feature will work but will run less efficiently if the client is new and the server old.

There is no need to dump and reload your repositories. Subversion 1.15 servers can read and write to repositories created by earlier versions. To upgrade an existing server installation, just install the newest libraries and binaries on top of the older ones.

Subversion 1.15 maintains API/ABI compatibility with earlier releases, by only adding new functions, never removing old ones. A program written to any previous 1.x API can both compile and run using 1.15 libraries. However, a program written for 1.15 cannot necessarily compile or run against older libraries.

There may be limited cases where the behavior of old APIs has been slightly modified from previous releases. These are cases where edge cases of the functionality have been deemed buggy, and therefore improved or removed. Please consult the API errata for more detailed information on what these APIs are and what impact these changes may have.

New Feature Compatibility Table

New Feature Minimum Client1 Minimum Server Minimum Repository Notes

Upgrading the Working Copy

Subversion 1.15 supports the working copy formats used by Subversion 1.0 and newer, as follows:

  • Before using Subversion 1.15 with an existing Subversion 1.7 or older working copy, users will be required to run the svn upgrade command to upgrade working copy metadata to the new format. This command may take a while in some cases, and for some users, it may be more practical to simply checkout a new working copy.
  • Subversion 1.15 can read and write existing Subversion 1.8 through 1.14 working copies in-place, without upgrading them. Subversion 1.8 through 1.15 can be used interchangeably on such working copies. (Internally, these are termed "format 31" working copies.)
  • Additionally, Subversion 1.15 adds a new working copy format that cannot be read by Subversion 1.14 and older. (Internally, these are termed "format 32" working copies.)

By default, both svn checkout and svn upgrade will produce working copies supported by Subversion 1.8 through 1.15 (format-31).

To instruct Subversion to use a particular working copy format, pass the new --compatible-version=1.15 command-line option to these commands. This will choose the newest format that is compatible with the specified version of Subversion. If you use multiple Subversion clients, pass the version number of the oldest client that will operate on the working copy.

Document what's new in format 32

Note: Subversion 1.15 cannot upgrade working copies that a 1.6 client would have refused to operate upon before an svn cleanup was run (with a 1.6 client). In other words, before upgrading to 1.8 or newer, a 1.6 or older client must be used to run svn cleanup on all 1.6 or older working copies that require cleanup. Likewise, Subversion 1.15 cannot upgrade corrupt working copies. Unfixable problems can arise from missing or corrupt meta-data inside .svn directories. Such damage to the working copy is permanent, and cannot be fixed even if svn cleanup is run prior to the upgrade.

If your working copy does not upgrade cleanly, please check out a new one.

New Features

Pristines On Demand

Point to the "User Guide" in notes/i525/. Regenerate /docs/i525-user-guide.html from the source markdown.

At the user's option, the storage space requirement of a Subversion working copy can be reduced by up to 50%.

All Subversion working copies require extra storage space in addition to the size of the checked out files. By default, the total storage space required is slightly more than double the size of the checked out files.

Subversion uses most of that extra space to cache each file's BASE revision ("pristine") so that operations such as diff and revert can work offline, and commit can send just the modified portions of a file to the repository server rather than the whole file. This design optimises the speed and availability of these operations on the assumption that network connectivity to the repository may be a bottleneck while local storage is cheap.

In some use cases, it may be more sensible to fetch one or more pristines from the repository server when needed ("on demand"), rather than to cache all pristines all the time. Some example use cases:

  • Very large files that change infrequently. In this case, the pristine is usually not needed but takes up space, doubling the storage requirement and providing little or no benefit.
  • Working copies on storage-constrained devices with a fast, always-on connection to the repository server. In this case, network bandwidth is more readily available than local storage, inverting the original design assumption that local storage is cheap.
  • Working copies on the same device as the repository.

As of Subversion 1.15, users can opt for Pristines On Demand at checkout time. This applies to the entire working copy:

$ svn checkout --store-pristine=no $REPO $WC

The command to check out a normal working copy is unchanged, but users may explicitly write yes:

$ svn checkout --store-pristine=yes $REPO $WC

When using Pristines On Demand, instead of caching pristines for all files all the time, Subversion will only fetch and cache those of individual files when needed, and will eliminate them when no longer needed.

Note that the space savings come at a tradeoff of requiring a connection to the repository for more operations as compared to a normal working copy and may, depending on network speeds and file sizes, introduce a perceptible delay when a pristine is downloaded.

The following table lists the Subversion commands that behave differently when using Pristines On Demand. For each command, it shows the difference in how that command accesses the repository.

Working Copy Type
Command Normal Pristines On Demand
cat (BASE) Never Hydrate
commit Send-Delta Send-Full
conflict resolving (resolve/merge/up/sw) Sometimes Sometimes (...)
diff (BASE) Never Hydrate
revert Never Hydrate
update/switch Always Always + Hydrate

Legend:

  • Never: Does not contact the repository server.
  • Always: Always contacts the repository server.
  • Hydrate: This operation downloads and keeps the pristine for each file that has a local content modification (i.e., when svn status shows M in the 1st column) when its pristine is not already stored in the working copy. See notes 1 and 2 below.
  • Send-Delta: Sends just the locally modified parts of each file's content.
  • Send-Full: Sends the complete content of each locally modified file.

Additional Details:

Once downloaded, Subversion keeps a file's pristine locally cached in the working copy, so that further operations on the file will not download it from the repository again. It keeps the pristine until one of these operations either restores the file to an unmodified state or detects that the file is no longer modified. For example, commit and revert will immediately discard the pristine of each file they operated on, because that file will no longer be locally modified, whereas diff will discard the pristine only if it finds there are no differences.

Note 1: At the beginning of a given operation, Subversion will download missing pristines of at least the files that this particular operation will use. It may download those of other files too, that this particular operation will not use. For example, in the initial implementation of this feature, Subversion considers all potential files in the smallest subtree that spans all the target files of the operation. The details of this behaviour are subject to change before and after the feature is released.

Note 2: In evaluating differences between a file's working text and its BASE text, Subversion takes into account the "EOL style" and "keywords" settings. (See the svn:eol-style and svn:keywords properties.) Just as svn status does not show M in the first column for such differences, neither will these cause the pristine to be downloaded from the repository.

Limitations and Future Possibilities:

Currently, this feature applies to an entire working copy. That is, either all working files have their pristines cached (the default) or all working files use pristines on demand (--store-pristine=no). In the future, this feature may be enhanced to give users more granular control, such as by allowing the --store-pristine switch to apply to individual files.

Multi-WC: Multiple Working Copy Format Support

Subversion 1.15 introduces a new working copy format (internally called Format 32) to support Pristines On Demand. Subversion 1.15 or newer is required to operate on working copies in this new format.

For user convenience, Subversion 1.15 avoids the need to upgrade working copies unless the new features are used. This is accomplished in two ways:

  • Multi-WC: Subversion 1.15 introduces support for operating on multiple working copy formats. Currently, two formats are supported. These are:
    • Format 32: Compatible with Subversion 1.15 and newer. Supports Pristines On Demand.
    • Format 31: Compatible with Subversion 1.8 and newer. Maximizes compatiblity in case older Subversion clients are used.
  • Using Format 31 by default, unless the user selects Format 32 explicitly or opts in to Pristines On Demand.

For example, a user who does not need Pristines On Demand may use a 1.15 svn command line client interchangeably with a third party GUI client or other software package that incorporates 1.14 or older Subversion libraries.

However, if using Pristines On Demand, or if Format 32 was selected explicitly, a 1.15 or newer client is required. Attempting to operate on such a working copy with an older client will result in an error, such as:

svn: E155021: This client is too old to work with the working copy at
'/path/to/working/copy' (format 32).
You need to get a newer Subversion client. For more details, see
  http://subversion.apache.org/faq.html#working-copy-format-change

Currently, Pristines On Demand is the only feature that requires a newer working copy format, but newer features and working copy formats to support them may be added in future Subversion release lines.

Streamy Checkouts

This new feature delivers a noticeable speed-up for svn checkout and svn update while addressing reports of network connection timeouts that could occur in the middle of these operations.

Previous versions of the Subversion client would fetch files from the server into the working copy's administrative directory, where each file's BASE revision is cached, and then separately "install" them to their proper location in the working copy. The "install" step involves copying and possibly translating the files to account for things like svn:eol-style and svn:keywords. This step was done per-directory and during that time, the client would hold the connection to the server open without reading anything through it. If this communication silence went on for too long, the server would eventually timeout and close the connection from its end, leading to annoying errors on the client side.

For example, assuming a 60 second HTTP timeout (the default in httpd 2.4.x) and reasonably fast storage on the client side, timeouts could be expected to occur while installing any directory about 6 GB in size or larger. (This value could vary significantly based on numerous interrelated factors.)

This issue is addressed by making the checkout stream data to both the administrative directory and the projected working file simultaneously, reducing the actual "install" to an atomic rename. As a result, the svn checkout and svn update operations no longer hold the connection open without reading from it, eliminating the timeouts.

Clients will enjoy a noticeable speed-up due to improved network performance and reduced storage-level I/O.

Note: Streamy Checkouts are not yet implemented for svn export.

Enhancements and Bugfixes

Command-line client improvements (client)

Server-side improvements

Client- and server-side improvements

Plaintext credential cache is supported by default on Unix-like systems

Subversion supports several credential caches to prevent re-typing usernames and passwords repeatedly. Which credential cache(s) are used depends on the operating system, compile-time options, and the user's runtime configuration. On Windows and macOS, Subversion uses OS facilities to save passwords in encrypted form. Unix-like operating systems do not have a single standard facility to do this; on these systems, Subversion supports up to four credential caches: GNOME Keyring, KWallet, GPG Agent, and (as a fallback) the Plaintext cache.

The rest of this section discusses the Plaintext cache and is applicable only to Subversion clients running on Unix-like operating systems.

In Subversion 1.12 through 1.14, write access to the Plaintext cache was disabled by default at compile-time. Binaries compiled in the default configuration could not store new plaintext credentials, but would continue to use any that were already stored. Users and binary packagers could explicitly enable write access to the Plaintext cache by compiling Subversion with the --enable-plaintext-password-storage option to configure. (See r1845377.)

Unfortunately, this has caused a variety of problems for users, especially when using the svn client in unattended processes such as CI systems, or on remote machines through ssh (a GUI password prompt would display on the remote machine, inaccessible to the ssh user). Users reported that they had to employ workarounds that caused passwords to be stored in plaintext anyway, or refused to upgrade their Subversion installations to these releases. Some binary packagers built with --enable-plaintext-password-storage while others didn't, creating inconsistent experiences within the same release lines.

Based on the feedback received, Subversion 1.15 inverts the default. (See r1909351.) Binaries compiled in the default configuration can once again store new plaintext credentials (after warning and asking the user). Sites that wish to eliminate this possibility can do one or both of the following:

  • Compile Subversion with the --disable-plaintext-password-storage option to configure or install a binary package that was compiled this way. Be aware that users can circumvent this by compiling or installing their own Subversion binaries and/or by creating a plaintext cache manually.
  • Allow encrypted stores like GNOME Keyring and KWallet, but not the Plaintext cache, by setting store-plaintext-passwords = no in Subversion's run-time config settings. See the per user files at ~/.subversion/config and ~/.subversion/servers, and the systemwide files at /etc/subversion/config and /etc/subversion/servers.

For more on plaintext credentials, see the FAQ entry.

Known issues in the release

There are no known issues specific to this release at the moment.

Subversion 1.15.x is a Regular Release

1.15 is a regular release, not a Long-Term Support release. See Supported Versions and How We Plan Releases.