Friday, October 25, 2013

Unshelve shelveset created from one branch to another


Unshelve shelveset created from one branch to another

When you need to unshelve to a different branchTFS power tool will help… 

The power tool command /> tfpt.exe unshelve can be handy for the following,
·         Allows a shelveset to be unshelved into a workspace with pending changes.
·         Merges content between local and shelved changes.
·         Allows migration of shelved changes from one branch into another by rewriting server paths.
·         Allows changes from an already-unshelved shelveset to be undone, cleaning up pending adds, and preserving other existing pending changes in the workspace.


Below is a list of features that are installed with the March 2011 Power tool installation.

Once the installation is complete, go to the cmd and type />tfpt.exe

we are interested in />tfpt unshelve to achieve unshelving of a shelve set to a different branch

Syntax
/>tfpt unshelve [shelvesetname[;username]] [/nobackup]
                     [/migrate /source:serverpath /target:serverpath]
shelvesetname          The name of the shelveset to unshelve
/nobackup              Skip the creation of a backup shelveset
/migrate               Rewrite the server paths of the shelved items
                        (for example to unshelve into another branch)
/source:serverpath     Source location for path rewrite (supply with /migrate)
/target:serverpath     Target location for path rewrite (supply with /migrate)
/undo                  Undo pending changes from an unshelved shelveset
/batchsize:num         Set the batch size for server calls (default 500)

Sample
/> tfpt unshelve “MySampleShelveNamel;AD\username” /migrate /source:”$/MyTeamProject/TheOrigionalBranch” /target:”TheDestinationBranch”
Catches
If you get the error => "unable to determine the workspace"

NOTE: Take the latest from your source control and “cd” to a local path that is mapped to the target workspace. Also ensure that the current working directory is mapped, you can run "tf workspace" and see if the target folders are mapped. 

No comments:

Post a Comment