Skip to content

Latest commit

 

History

History
35 lines (25 loc) · 2.37 KB

Challenge-07.md

File metadata and controls

35 lines (25 loc) · 2.37 KB

Challenge 07 - Azure Repos: Branching & Policies

< Previous Challenge - Home - Next Challenge >

Introduction

Now that we have a deployed instance of our code, we are likely going to get a request to add a feature to our code. To this we need to implement a branching strategy. Review the below articles on the basics of a Git branching strategy and the modified version Microsoft uses called Release Flow.

  1. Git Branching Strategy
  2. GitHub Flow
  3. Release Flow

Description

In this challenge we will first create a second build pipeline that will build and run unit tests on any code before it gets checked into the master branch. We will also implement a few policies in Azure DevOps to ensure that our team is following the rules. Finally we will make a change to our code to see how branching in Git works.

  • Clone the build pipeline that we created earlier.
    • Remove all but the restore, build and test tasks.
    • Turn off the continuous integration trigger.
  • Setup a Branch Policy to protect our master branch, hint. The policy shall:
    • Require at least 1 reviewer, however users should be able to approve their own changes (NOTE: you will likely not want to do this in a real app)
    • Require at least 1 linked work item.
    • Perform a Build validation using our new build pipeline.
  • Using a simple Git Branching strategy lets make a change.
    • Your manager has asked that you update the copyright information at the bottom of the site, currently it says © ASP.NET Core and it should say © 2019 Contoso Corp.
    • Create a Work Item requesting we implement the feature.
    • Make the change in your code. Be sure to make this change on a new "feature branch"
    • Create a Pull Request to merge the change into master. Notice how the policies you set are audited on your pull request.
    • Complete your pull request.

Success Criteria

  1. You should see the change you made deployed to all three of your environments.
  2. Your work item should be in the "closed" state.