Skip to main content

MAC SVN to GIT

Atlasssian provides a wonderful tutorial on how to use their migration scripts to move your subversion code repos to their BitBucket Git Repository https://www.atlassian.com/git/tutorials/migrating-overview .

However their are a few things that all developers inevitable run into that are not explicitly documented.  I figured I would document the few things I ran into during my migration process and maybe save a few other developers a few moments.

Tip 1: Re-mounting sparseimage

I was undertaking my migration from MAC OS X (Yosemite).  Since the MAC OS is a case insensitive OS, I had to follow the instructions provided in the Atlasssian Migration guide to "Mount a case-sensitive disk image".  It worked great except of course I had to abandon my efforts and come back the next day.  Well the mount point was gone after I exited my terminal session.  The sparse image still existed. In order to remount the sparseimage I had to use the hdiutil.

cd ~
hdiutil attach ~/GitMigration.sparseimage -mountpoint ~/GitMigration


Tip 2: Extracting author information

Then as the next part of the "Preparedness" section of the migration tutorial Atlassian describes how to extract author information from your subversion repository:

java -jar  ~/svn-migration-scripts.jar authors <svn-repo> > authors.txt

Well when I tried to execute the extraction against my protected subversion repository I received the following error:

About to create the authors file.
svn: E215004: Authentication failed and interactive prompting is disabled; see the --force-interactive option
svn: E215004: Unable to connect to a repository at URL 'http://www.foo.com/svn/repos'
svn: E215004: No more credentials or we tried too many times.
Authentication failed

Could not communicate with Subversion: check the URL of the repository, the username and the password are all valid

te

Well no where within the migration document does it indicate how to provide credentials to the scripts jar. Well take note you can pass username and password following the syntax:

$ java -jar svn-migration-scripts.jar authors
<URL> [<username> [<password>]]

Once I provided my proper credentials for the repository

java -jar  ~/svn-migration-scripts.jar authors http://www.foo.com/svn/repos fakeusername fake password > authors.txt

I was then successfully able to create the authors.txt file with the author information.

Next step according to Atlassian's migration guide was to edit the authors.txt file and change each of the usernames to the right of the equal sign to the appropriate fullname of the user/author.  I just used vi and made the modifications.

Ok preparation steps were completed.  Moving On...

Convert

The convert portion went very smoothly.  It may be a little more difficult if you didn't follow a standard svn layout.  

-- Project Name/module
   |
   -- trunk
   |
   -- branches
   |
   -- tags

Since I was working with standard, closed out projects I then just proceeded to run the conversion command

git svn clone --stdlayout --authors-file=authors.txt http://<svn-repo>/<project-location> <nameOfDirToCreate>

Note: Since Git v2.x you will want to add an option to the command above otherwise your SVN branches and tags will not properly get imported.  With Git v2.x the svn clone command implies the prefix "origin" which was empty by default in the Git 1.x.You will want to use

git svn clone --prefix="" --stdlayout --authors-file=authors.txt http://<svn-repo>/<project-location> <nameOfDirToCreate>

The process ran for a few minutes for a small project.  You may get some seemingly concerning warnings at the beginning of the progress, but they are clearly followed by warnings informing you not to be concerned as "git-svn is just searching aggressively for old history".

When the process is completed you should be left with directory as you specified in the command.

Once this is completed you are apply to explore your new Git repository.  One note is that SVN branches and tags will not appear as local branches within Git.  The Git svn clone command imports all SVN branches as remote branches, SVN tags being prefixed with tags/ .  It is indicated that this is primarily done to support two way synchronizations going forward.  Since I wasn't interested in supporting two way synchronization I just proceeded to the next step of the conversion (Clean Up). To see what will be cleaned up in the Git Repo you can run the clean up script without the -force option within the the repo directory you created.

java -Dfile.encoding=utf-8 -jar ~/svn-migration-scrips.jar clean-git

Once again this will display all the changes to be made, but will not actually apply any of them.  There wasn't any concerns with the information that was provided in the output on my particular repo and I proceeded with the --force.

Synchronize

As Atlassian indicates in their documentation it is possible to synchronize in both directions, from the new Git Repo and the SVN repo.  However they don't recommend it.  I would certainly agree to avoid the complexity, if you can.  During the transition period just use a one way sync process allowing commits to your SVN repository and follow the instructions to re-sync the changes to your new Git Repository.

In my particular cause I was just ready to cut over and start using Git.  So there was no need for continued sync steps.  

Share

So now I was ready to share out the converted repo to the distributed Git Repo (BitBucket).  You essentially need to create a bitbucket account and follow the instructions for creating a repository.

Then you will create a remote origin to your local, converted Git Repo.  The command should be run in thew root of the <nameOfDirToCreate> you created back in the convert.
  
git remote add origin https://user@bitbucket.org/user/repo_name git

Once the origin is created follow the push steps and your content should be successfully posted on BitBucket.

Migrate

Then really the migrate step consists of getting your developers to stop committing to SVN and start using Git.  The Atlassian guides do provide some nice recommendations as far as back ups and making SVN read only.  Use if you feel they are appropriate.  

Now you just need to get familiar with using Git and decide which workflow you want to standardize on for development.  Check out Atlasssian comparison of workflows.

Comments

  1. Thanks for you info - when you did your "authors" step - how long did it take for you? I was expecting it to be quick, but my command is just 'sitting there' not spitting anything out (errors or authors).

    I have confirmed that my credentials are correct, based on confirmed failure when I give the wrong ones. Any clues?

    ReplyDelete
    Replies
    1. It didn't take long at all. Did it ever complete? I wonder if there are some permission issues with the user/credentials you are trying to use?

      Delete

Post a Comment

Popular posts from this blog

Where to start on AngularJS for Java Developer

Background: If you are a Java developer who is comfortable using Eclipse (JEE Developer version) you may be asking yourself where to start with AngularJS. There is all kinds of documentation out there in regards to AngularJS and https://angularjs.org/ provides, to the point, tutorials on how to get started. You can certainly go that route and use node.js embedded server and possibly a Javascript focused IDE like WebStorm. However I wanted to try and stay in a comfort zone, my comfort zone, of Eclipse and be in a position to deploy an Angular application to a container like Tomcat. This blog entry will present the trail I took to try and accomplish it. Note: This is an adventure into Angular 1.x, not 2.x.  I would imagine this could all work with 2.x as well as it is focused on the dev environment setup. Start: Well the one consistent thing you will find to get started is to install the AngularJS Plugin, provided by Angelo ZERR.  You can use the Eclipse 4.5 (Mar...

WSO2: Simple Pass through proxy (REST to REST with HTML Reply)

Today I set out on trying to set up a simple passthrough proxy that would allow for a GET request to be made to REST style backend services that replies with HTML content. The proxy services was being set up on WS02 ESB v4.8.0.  I thought this was really going to be as simple as walking though their wizard and setting up a new proxy endpoint that just handed off to the behinds the scene service. It was straight forward to set up the proxy, but then unfortunately when called it just didn't respond. It took quite awhile to figure out what the issues was.  At first I was using the ESB admin console and review the System and Application Logs.  The Application Logs were certainly more useful, but they still truncated stack traces which made it hard to clue in on the real issue. It wasn't until I went and review the logs on the server that I was able to detect the cause.   <wso2_esb_root>/repository/logs/wso2-esb-errors.log 2015-03-19 16:09:43,00...

Database Leak: getConnection() within Spring Transaction

I recently encountered an issue where one of my teammates was experiencing an issue where an application datasource would periodically become exhausted.  After discussing it a few times, we hypothesized that it was a situation where there was a database connection leak.  It was suspected the leak was within boundaries of some application code with a low call rate.  This would line up with, why the application would run for an extended period and then all of a sudden max out its database connections. By inspecting the logs around the times of the database connection pool becoming exhausted it became pretty clear the potential location of the problematic code. The cause of the issue was not a result of necessarily bad code writing, but more of a case of not knowing how legacy semantics would work within the context of a spring transactional boundary. The semantics of how a call to DataSource.getConnection() behaves within the Spring transaction boundary is probably not ...