Any tool to migrate repo from Vault to Subversion?

2019-01-31 19:04发布

Are there any tools to facilitate a migration from Sourcegear's Vault to Subversion?

I'd really prefer an existing tool or project (I'll buy!).

Requirements:

  1. One-time migration only
  2. Full history with comments

Optional:

  1. Some support for labels/branches/tags
  2. Relatively speedy. It can take hours but not days.
  3. Cost if available

Bonus points if you can share personal experience related to this process.


One of the reasons I'd like to do this is because we have lots of projects spread between Vault and Subversion (we're finally away from sourcesafe). It'd be helpful in some situations to be able to consolidate a particular customer's repos to SVN.

Additionally, SVN is better supported among third party tools. For example, Hudson and Redmine.

Again, though: we're not abandoning vault altogether.

5条回答
放我归山
2楼-- · 2019-01-31 19:37

If you want full version history, you may want to just write a script that checks out each version from vault and checks it in with the comments to Subversion.

https://www.mercurial-scm.org/wiki/GenericConversion is a good example

Based on the documentation that I saw on the Vault website, look into the command line GETVERSION.

Use your favorite scripting language... Implement the following process:

  1. Check out a version from vault.
  2. Get the commit comments for the changeset.
  3. Add/remove the files to the SVN repo
  4. Commit files using the commit comments
  5. Go back to step one with the next version
查看更多
倾城 Initia
3楼-- · 2019-01-31 19:52

We are thinking about migrating from vault to git. I wrote vault2git converter that takes care of history and removes vault bindings from *.sln, *.csproj files.

Once you have git repo, there is git2svn.

I know it sounds like going rounds, but it might be faster than writing vault2svn from scratch.

查看更多
一夜七次
4楼-- · 2019-01-31 19:56

I never found an easy way to convert from Vault to svn. Basically we took our latest branches and trunk and started new in svn. Honestly I went two or three labels back, just because. I kept the vault db around for six months and we never needed to go back to it for data. So I assume you want to carry forward your history for a bug tracker tie-in; at this same time we transferred our outstanding bug list to a new tracker, so that definitely made things more convenient. If we where staying with the same bug tracker, I would think we would of started a new instance of it for the new repo. Good Luck!

Brett

查看更多
家丑人穷心不美
5楼-- · 2019-01-31 19:56

Free. The vault user license costs have tripled since we went to it.

查看更多
趁早两清
6楼-- · 2019-01-31 19:59

We are considering migration as well. One reason is cost, but another reason is that Vault does not use valid xml (or any) for its commit comments so special characters fail our automated CCNet build system (e.g. a bullet character is one of them, and specifically causes us a problem). A way around this has been to A) ask our developers to not use these special, "invalid" characters (characters outside the range of ASCII 32 - 126) and B) to manually go in and re-commit code with a "valid" comment. This may not seem like a big deal, but not allowing these characters prevents easy copy/paste of bug and other comments into the commit comment. This slows people down and anything that hinders flow and productivity and creates frustration needs to be reduced or removed.

From my research, it seems that there is no way to directly migrate from Vault to SVN. Perhaps it is possible to use another version control system as a migration middle step: Vault --> OtherSourceControlProduct --> SVN

...but I think that we would either script the commits (as Joshua suggested at the beginning of this thread) or - which more likely - just commit the last few revisions and leave the Vault repos around a while for history, etc. This actually gives us a a good opportunity to clean out and refactor our current code and hierarchy.

Paul

查看更多
登录 后发表回答