Skip to main content

Understanding Code Changes

Understanding Code Changes. General. Code changes is a metric that measures the changes that are done in the code base over time. It includes either new code or refactored code and is counted in a nu…

Understanding Code Changes

General

Code changes is a metric that measures the changes that are done in the code base over time. It includes either new code or refactored code and is counted in a number of code lines that were changed over time.

Code changes are an important metric because it gives an indication regarding the size of a task and the risk level this task holds. The bigger the code changes number the higher risks that it presents. This metric is also important as one of the metrics that follow the throughput and productivity of individual/team/organization over time.

Calculations

Just like with Work Breakdown, LinearB uses git blame to calculate the number of changes to a line of code. Because the entire commit chain leading up to the commit being evaluated is taken into account (rather than simply running a diff against the release branch of the code), the Code Change value should be accurate even if the last modification of a particular line was not merged back to the main release branch before being changed. This allows LinearB to track code changes that happen during the code review process, for example.

Example

Let's say that above, orange represents our main branch and blue represents a feature branch. There were 4 commits to the feature branch before it was merged back to main. This consists of:

  • Commit 1 - Added 30 new lines of code
  • Commit 2 - Added 22 new lines of code
  • Commit 3 - Rewrote 5 of the lines added in Commit 2
  • Commit 4 - Deleted 10 lines added in Commit 1

Calculating changes:

  • Commit 1 - 30 changes
  • Commit 2 - 22 changes
  • Commit 3 - 5 changes
  • Commit 4 - 10 changes

This means that we would calculate this as 67 changes, even though there are only 42 new lines of code ultimately merged in to the main branch.

How did we do?

How is Cycle Time Calculated?

Understanding Releases

Contact