Skip to content

Latest commit

 

History

History
103 lines (60 loc) · 5.23 KB

overview.md

File metadata and controls

103 lines (60 loc) · 5.23 KB

Overview

The Jira to Azure DevOps work item migration tool lets you export data from Jira and import it as work items in Azure DevOps or Microsoft Team Foundation Server.

The migration process is done in two phases, first data is exported from Jira to text files. This can be done in a number of batches until the right set of items are ready for import.

The second step imports the data files to work items in Azure DevOps/TFS.

The key capabilities of the tool includes:

  • Jira items are exported based on JQL queries.
  • Users can be translated during migration in order to maintain proper history.
  • Field mapping is provided to map fields from the source to target account based on configuration file.
  • State mapping between Jira and Azure DevOps states.
  • History from Jira is maintained.
  • Dates such as created or changed date are maintained.
  • Area/Iteration paths can be defaulted to a specific value when they don't exist in the target project.

Migration process

Note: The tool is implemented as a Windows executable and will only work on Windows (duh!). We have plans to convert the project to .NET core to support running the migrations on MacOS or Linux. When that happens this section will be removed.

Jira requirements

  1. Identify the migration account (username and password) to access Jira
    Note:

    401 exceptions can occur when you use your email address rather than username. To resolve this use -u USERNAME.

    If you continue to receive 401 exceptions your password may be causing the issue, go to https://id.atlassian.com/manage/api-tokens and generate an API token. Use this token the same way you would your password -p API_TOKEN

    If you receive a 400 error after the "Retrieving Jira link types" process starts you need to use your email address as your username -u EMAIL_ADDRESS

  2. Get the url to Jira and the name of the source project

Azure DevOps/TFS requirements

  1. Get the name of the target Azure DevOps organization/TFS collection
  2. Aquire a personal access token for the organization/collection with the following scopes: Work Items (Read, write, & manage) as minimum requirement.
  3. Get the url and the name of the target project. The import tool can create the target project if it does not already exist.
  4. Discuss how users should be mapped between Jira and Azure DevOps/TFS.

Migrate work items

The process below describes the high-level steps requred to migrate data from Jira to Azure DevOps.

  1. Define a Jira JQL filter for the items to export, for instance here's how to export all stories and sub-tasks from the SCRUM project:

     project = SCRUM AND issuetype in (Story, Sub-task) ORDER BY Rank ASC
    
  2. Define how to map users

    This is an optional step but it's common that the names/account in Jira and Azure DevOps/TFS are different. Map Jira users to Azure DevOps/TFS users in a text file with email value pairs in when using Jira Server and accountId/email value value pairs when using Jira Cloud like this. It is possible to use email value pairs for Jira Cloud too but then the users emails must be set public:

     Jira Cloud example:
    
     [email protected]
     
     Jira Server example: 
     
     [email protected][email protected]
    

    If no specific path to the user mapping file is provided in the configuration file, the program expects it in the location of "workspace" setting. If no file name or path including file name is provided, the import just skips mapping users.

    To add support for setting a default user when the Jira user of a task is not found in the user mapping file just add this in the user mapping file:

     *=default username
    
  3. Define configuration for the migration process.

  4. Run the export phase.

  5. Review the export logfile (created for reference and troubleshooting).

  6. The migration process tracks progress in a journal file. The journal makes it possible to resume a migration, for instance to import items that failed in the import due to configuration issues.

  7. The export will generate migration items for all Jira isses.

  8. Run the import phase.

  9. Review the import logfile (created for reference and troubleshooting).

Configuration schema

The options for configuring the migration process is documented here.

Sample

Sample configuration files are provided with documentation of typical migration settings in the "samples" folder.

Sample Description
config-agile.json Configuration to migrate to an Agile process template
config-basic.json Configuration to migrate to a Basic process template
config-scrum.json Configuration to migrate to a Scrum process template

Known limitations

  • Artifact links (other than git) are not migrated
  • Board fields are not migrated