# HG changeset patch # User Martin von Zweigbergk # Date 1458972332 25200 # Node ID c4b727795d6a5770ec523c1965b464baed81097f # Parent 07f1fbf1f75876e17bcf28757caf8e44a73547cd bundle: avoid crash when no good changegroup version found When using treemanifests, only changegroup3 bundles can be created. However, there is currently no way of requesting a changegroup3 bundle, so we run into an assertion in changegroup.getbundler() when trying to get a changroup2 bundler. Let's avoid the traceback and print a short error message instead. diff -r 07f1fbf1f758 -r c4b727795d6a mercurial/commands.py --- a/mercurial/commands.py Fri Mar 25 16:13:28 2016 -0700 +++ b/mercurial/commands.py Fri Mar 25 23:05:32 2016 -0700 @@ -1399,6 +1399,10 @@ base = scmutil.revrange(repo, opts.get('base')) # TODO: get desired bundlecaps from command line. bundlecaps = None + if cgversion not in changegroup.supportedoutgoingversions(repo): + raise error.Abort(_("repository does not support bundle version %s") % + cgversion) + if base: if dest: raise error.Abort(_("--base is incompatible with specifying " diff -r 07f1fbf1f758 -r c4b727795d6a tests/test-treemanifest.t --- a/tests/test-treemanifest.t Fri Mar 25 16:13:28 2016 -0700 +++ b/tests/test-treemanifest.t Fri Mar 25 23:05:32 2016 -0700 @@ -736,3 +736,9 @@ bundle requirements: generaldelta, revlogv1, treemanifest $ hg debugbundle --spec repo-packed.hg none-packed1;requirements%3Dgeneraldelta%2Crevlogv1%2Ctreemanifest + +Bundle with changegroup2 is not supported + + $ hg -R deeprepo bundle --all -t v2 deeprepo.bundle + abort: repository does not support bundle version 02 + [255]