Customize the workflow (Inheritance process)

Azure DevOps Services | Azure DevOps Server 2022 - Azure DevOps Server 2019

Each work item type is associated with a workflow that supports tracking the status of work as it moves from creation to completion. To support your business and team processes, you can add custom states to most work item types (WITs). For example, you may want to insert a Triaged state for bugs, or a Design state for features or user stories.

Here, the Bug WIT has been customized to support a Triaged state. The state and reason fields appear on the work item form in the header area.

Bug work item form, header area, added state

This article addresses the supported workflow customization options and how to customize a workflow. Specifically, you'll learn about:

  • Supported workflow customization scenarios
  • Impact to team boards when you customize a workflow
  • End-to-end workflow customization steps
  • How to add or remove a custom workflow state
  • How to hide or unhide an inherited workflow state
  • How to view a graphic depiction of the state model

For documentation on the workflow for build and release DevOps tasks, see Use Azure Pipelines.

Important

The Inheritance process model is available for projects configured to support it. If you’re using an older collection, check the process model compatibility. If your on-premises collection is configured to use the on-premises XML process model, you can only use that process model to customize the work tracking experience. For more information, see Choose the process model for your project collection.

Supported customizations

You can customize the workflow of any work item type (WIT) by hiding inherited states or adding custom states. Inherited states differ based on the system process —Agile, Basic, Scrum, or CMMI, —you chose from which to create your custom process.

Each default workflow for each WIT defines between two and four States and specifies the following workflow operations:

  • Forward and backward transitions between each state
  • Default reasons for each state transition

For example, the Basic process, Issue WIT is characterized by the three States—To Do, Doing, and Done—and transitions shown in the following image.

Basic Process, Issue work item type, workflow state model


State types

Supported customizations


Inherited icon Inherited states

Custom states


Workflow states must conform to the following rules

  • You must define at least one state for either the Proposed or In Progress State categories

    Note

    Before adding a workflow state, review Workflow states and state categories to learn how workflow states map to state categories.

  • You must define at least two workflow States
  • You can define a maximum of 32 workflow States per work item type

Unsupported workflow customizations

  • You can't modify an inherited state (you can't change its name, color, or category), but you can hide it
  • You can only have one state in the Completed state category. If you add a custom state to the Completed category, any other state is removed or hidden
  • You can't change the name of a custom state
  • You can't specify a Reason for a state, instead, default reasons are defined such as Moved to state Triaged, Moved out of state Triaged
  • You can't change the location of the State and Reason fields on the form
  • You can't customize state category names
  • You can't modify an inherited state (you can't change its name, color, or category), but you can hide it
  • You can only have one state in the Completed state category. The system disallows adding any custom state to this category
  • You can't change the name of a custom state
  • You can't change the order of states, states are listed in their natural sequence based on their state category within the drop-down list of a work item form
  • You can't specify a Reason for a state, instead, default reasons are defined such as Moved to state Triaged, Moved out of state Triaged
  • You can't change the location of the State and Reason fields on the form
  • You can't restrict transitions, all transitions are defined from any state to another state.

State drop-down menu sequence

The State drop-down menu lists States within the sequence you order them within each state category. For newly added work items, the first State in the Proposed category is assigned as the default State.

The following image illustrates the State sequence defined for User Story and its corresponding drop-down menu.

User story state sequence      User story State drop-down menu

Within each category, you can move custom states up or down.

Impact to teams with workflow changes

Teams may need to update their board configuration when the following customizations are made:

  • You add a custom State
  • You change the category of a custom State
  • You add a custom or inherited work item type to a backlog level (Customize your backlogs or boards)

States that you add to the task WIT adds columns to the Taskboard. If you track bugs along with tasks, then states you add to the bug WIT also add columns to the Taskboard. You don't have to add the same states to each of these WITs, however, you may want to do so in order to update the status in the same way and to minimize the number of columns that get added.

Prerequisites

Check out Configure and customize Azure Boards, which offers guidance on tailoring Azure Boards to align with your specific business requirements.

  • Organization requirement: Ensure you have an organization in Azure DevOps.

  • Permissions:

    • Be a member of the Project Collection Administrators group.
    • Have collection-level permissions such as Create process, Delete process, Edit process, or Delete a field from organization set to Allow.
    • These permissions allow you to modify processes and fields within your organization.
  • Project process model requirement:

  • Permissions:

    • Be a member of the Project Collection Administrators group.
    • Have collection-level permissions such as Create process, Delete process, Edit process, or Delete a field from organization set to Allow.
    • These permissions allow you to modify processes and fields within your organization.

Open organization process settings

  1. Sign in to your organization (https://dev.azure.com/{yourorganization}).

  2. Select gear icon Organization settings.

    Screenshot showing Organization settings button highlights.

  3. Select Process.

    Screenshot showing highlighted Process button for selection.

  1. Sign in to your collection (https://dev.azure.com/{Your_Collection}).

  2. Select Collection Settings or Admin settings.

  3. Select Process.

    Screenshot showing highlighted Process button in Collection settings.

Note

When you customize an inherited process, any projects using that process automatically reflect the customizations. To ensure a smooth transition, we recommend creating a test process and project, which allows you to test your customizations before you implement them organization-wide. For more information, see Create and manage inherited processes.

Add a workflow state

States you add appear in the drop-down menu for the States field shown in work item forms and the query editor. A transition to and from the State you add is created to every other State. Also, default reasons are defined, such as Moved to state Triaged, Moved out of state Triaged.

  1. From the Work Item Types page, choose the work item type you want to modify, choose States, and then choose New State.

    Process page, Bug WIT, States tab, Add state

    If the New state option is disabled, you don't have the necessary permissions to edit the process. See Set permissions and access for work tracking, Customize an inherited process.

  2. Enter the name of the State, choose its category and color, and then click Save. The color you specify appears throughout the product including on the work item form and when the State field appears on a backlog, boards, query results, and more.

    State menu in work item form

    Note

    Any workflow state you add to the In Progress or Resolved state categories will cause the Activated By/Activated Date and Resolved By/Resolved Date fields to update with workflow state changes in and out of these categories. For more information, see Query by assignment or workflow changes, Activated By/Date and Resolved By/Date fields.

  3. (Optional) To change the sequence of the State within the drop-down menu, choose the context menu icon and choose Move up or Move down.

    Move up State

  4. When you've finished adding states for the WIT, verify your changes by refreshing your browser and open a work item of the type you customized.

    Here we show the State drop-down menu with Triaged selected.

    Bug form, Triaged state added

  5. Remember, when you add a State to a WIT, which is associated with a backlog level, each team that uses the board needs to update their column settings.

Edit a state

You can edit the category or the color of a custom state. However, you can't change the name of the custom state.

  1. Choose Edit from the … context menu for the state you want to modify.

    Bug WIT, Edit custom state

  2. Modify the category or color, and then choose Save.

  3. If you change the category, teams that use the board need to update their column settings.

Hide or remove a custom state

When you hide or remove a state:

  • The state no longer appears in the State drop-down menu for the WIT
  • No changes occur to the work item history
  • Existing work items maintain their state value, but are in an invalid state. If you want to make a change to the work item, you must first update the state values. You may want to create a query and do a bulk update to move the affected work items into a valid state. If you add the state back to the work item type, the work items revert to a valid state.

Hide or unhide an inherited state

You can hide an inherited state that your team doesn't use in its workflow process. However, you must have at least one state defined for each category.

  1. Open the … context menu for the state you want to hide and choose the Hide option.

    Here we hide the Resolved state for the Bug WIT.

    Hide an inherited state

    Note

    If you hide the state of a WIT tracked on a board, each team that uses the board needs to update their column settings.

  2. To unhide, open the … context menu and choose the Unhide option.

Remove a custom state

  1. Open the … context menu for the state you want to remove, and choose Remove. You can only remove a custom state.

  2. From the Remove State dialog, click Remove.

    Remove state warning dialog box

View the State workflow model

You can view the State workflow model by installing the State Model Visualization Marketplace extension. This extension adds a new hub under Boards labeled State Visualizer. On that page you can choose a work item type and view the workflow state model.

Note

The State Model Visualization extension is not a supported feature of Azure Boards and therefore not supported by the product team. For questions, suggestions, or issues you have when using the extension, visit the extension page.

For example, the following image shows the Bug workflow that has been customized to have a Triaged state. This view illustrates the default transitions of the workflow model. All states can transition from one state to another.

Bug workflow that has been customized to have a Triaged state.

You can zoom in and zoom out of the view. Also, you can move the state nodes around to gain a better view of the state model.

Note

Review changes made to an inherited process through the audit log. For more information, see Access, export, and filter audit logs.