/ado-workitems-to-github-issues

Script to migrate Azure DevOps work items to GitHub issues including tasklists

Primary LanguageTypeScriptApache License 2.0Apache-2.0

Azure DevOps WorkItems to GitHub Issues Migration

TypeScript script to migrate AzureDevOps work items to GitHub issues. Inspired by https://github.com/joshjohanning/ado_workitems_to_github_issues.

Features

  • Migrate work item title and description or in case of a bug repro steps and system info
  • Migrate work item acceptance criteria
  • Migrate work item relations (child, related and predecessor) as a tasklist
  • Add a comment to the GitHub issue containing
    • the URL to the Azure DevOps work item
    • basic details (e.g. created by, created and more) in a collapsed details block
    • adds the work item as json in a collapsed details block

Usage

Prerequisites

  1. Install NodeJS
  2. In the GitHub repository, the work items are migrated to, create a label for each work item type that is being migrated (i.e. Bug => bug). The labels are added to the GitHub issue to identity the work item type.
  3. Checkout the repository and configure the parameters in the .env file
Parameter Description
ADO_TOKEN Azure DevOps personal access token with read permissions. write permissions are necessary, if a tag and comment should be added to the migrated Azure DevOps work item
ADO_ORGANIZATION Azure DevOps organization to migrate from
ADO_PROJECT Azure DevOps project to migrate from
GH_TOKEN GitHub personal access token with permission to create issues
GH_ORGANIZATION GitHub organization to migrate to
GH_REPOSITORY GitHub repository to migrate to
OPT_MIGRATE_CLOSED_WORKITEMS Option to migrate Done, Resolved, Closed and Removed work items. Possible values: [true, false]
OPT_ADD_TAG_MIGRATED_TO_GITHUB Option to add a tag and comment to migrated all migrated work items. Possible values: [true, false]

Example .env

# Azure DevOps
ADO_TOKEN=<ADO_TOKEN>
ADO_ORGANIZATION=example-org-ado
ADO_PROJECT=example-project
ADO_AREA_PATH=example-area-path

# GitHub
GH_TOKEN=<GH_TOKEN>
GH_ORGANIZATION=example-org-github
GH_REPOSITORY=exmaple-repository

# Options
OPT_MIGRATE_CLOSED_WORKITEMS=false
OPT_ADD_TAG_MIGRATED_TO_GITHUB=false

Run

NPM

npm run dev

PNPM

pnpm run dev

Addiotinal information

Todo