We are updating our knowledge base!

Please visit our new site at https://wiki.greensoftware.foundation/ for the latest information.

KPIs & Milestones

A milestone can be thought of as a version of the project, a deliverable, a release.

For instance you might define the milestones for a project as:

  • Proof of concept

  • Alpha

  • Beta

  • 1.0

Or perhaps

  • Sprint 1

  • Sprint 2

  • Sprint 3

In GitHub you can define milestones and then assign issues and pull requests to a specific milestones. Or you can create an Issue for a milestone and just list all the issues related to that milestone in that one Epic issue.

Every project in the Foundation should have at least the next milestone defined.

KPIs

KPIs are Key Performance Indicators, these are just things you are measuring to track the projects progress.

When deciding the milestone PMs also need to decide what KPIs, what metrics they will use to measure progress towards that milestone.

You can have one KPI or multiple.

In meetings PMs are expected to report a single %age progress towards the next milestone for every project

For example you might define a milestone as “Requirements Gathered” with KPIs:

  • Number of requirements submitted.

  • Number of requirements approved.

  • % requirements approved / target of 10 (assuming say we are targeting 10 core requirements)

Documenting Milestones

Every project wiki page should have a section called Milestones where we list the known/next Milestones, like so:

Milestones

ID: Name of the Milestone

Deliverable: What is the expected set of deliverables for this milestone.

Success: How will we define a successful milestone?

KPIs: What metrics are we going to use to track our progress towards this milestone?

PM’s are expected to report KPIs and progress towards each milestone every week in the In the https://greensoftwarefoundation.atlassian.net/wiki/spaces/~612dd45e45cd76006a84071a/pages/25002043

Milestone tracking for simple/smaller projects

The method described below is the proper way to setup milestones in GitHub.

However for smaller projects with just a few issues, or for repositories that are used to track multiple projects, it’s ok to manually track milestones using another solution, you can use summary GitHub issues, a view on a Project Board or even a separate Spreadsheet.

The most important aspect of Milestones is that it’s clear what the next milestone for a project is, it’s documented on the Project Wiki page and KPIs are being tracked and reported in the https://greensoftwarefoundation.atlassian.net/wiki/spaces/~612dd45e45cd76006a84071a/pages/25002043.

How to setup a milestone in GitHub

Go to your repositories milestone page, either directly through the URL like so https://github.com/Green-Software-Foundation/oc/milestones

Or click the Milestone button from the Issues tab like so:

Then press the New milestone button

Then add the relevant data to the Milestone

How to add issues and pull requests to Milestones

Once created you can add the Issue or PR to a milestone by clicking the gears icon next to the Milestone option.