Fetch metrics from JIRA and GitHub for a given set of users, for helping you checking information and visualize trends more easily.
In order to create your own spreadsheet, follow the given steps:
You can find the template here, with the given script already associated (you may also find the same script in this repository). All you need to do is make a copy of it for yourself.
Add your own tokens from JIRA and GitHub in order to access their APIs:
- For the JIRA token, it is necessary to prepend your email to it (ex.:
[email protected]:YOUR_JIRA_TOKEN
), and encode it using base64. - For GitHub, create a Personal access tokens (classic), and provide the needed accesses: repo, user & project.
- For Single sign-on organizations, it is necessary to authorize access to the repositories via SSO.
- Access your newly copied associated spreadsheet script via Apps Script (In the copied spreadsheet, access 'Extensions -> Apps Script'). It is necessary to replace the first two lines of code:
const jiraToken = 'Basic YOUR_EMAIL_&_JIRA_TOKEN_ENCODED'; // 'Basic XXX'
const githubToken = 'Bearer YOUR_GITHUB_TOKEN'; // 'Bearer XXX'
In order to generate an execution URL for your script, generate a New Deployment of an Web app type.
Add the newly generated Web App execution URL into the 'Settings' tab within your spreadsheet (B2 cell).
For fetching information of a given engineer, you need to follow three steps:
- Update both the sheet name and the given engineer name (B2 cell) to the same name/identifier. Ex.: John Doe.
- Add their given JIRA_ID (B3 cell) and GITHUB_USERNAME (N3 cell).
- Execute the correspondent generated scripts in C2 cell for JIRA and N2 cell for GitHub.
Team sheet uses its own query, but works similarly to the Engineering one:
- Update both the sheet name and the given team/project name (B2 cell) to the same name/identifier. Ex.: Payment Experience
- Also, it is necessary to adequate the query to your own needs. For example, update the project name: project = 'PX'.
Both are automatically populated according to the changes in the Engineer sheet(s). It might be necessary to adjust some charts if adding more engineers for a given platform (Android, iOS, and so on).
- For JIRA, different metrics provided will work accordingly depending on your team/project behavior and on filling some data:
- The "Days Spent" metric in JIRA is calculated from two dates: the date a task moves to "In Progress" and the date it moves from "Icebox" or "TODO." When both dates are available, the start date is the average of the two. Otherwise, it is the date the task exits "Icebox" or "TODO." This accounts for instances where tasks may not have been promptly updated to "In Progress." The metric's accuracy relies on the team's diligence in maintaining the board.
- Similarly, the reliability of "Priority" and "Story Points" metrics depends on the team's consistency in updating this information.
- When updating the Engineer(s) sheet(s), sometimes Google sheets doesn't automatically updates the information in the 'Team Overview' sheet. It is necessary to tweak it by "dragging" the functions from a given row above or below. Example: The information for line 5 (B5-AA5) is missing even if with all pulled information for "Engineer 1". Drag the formulas from range B6-AA6 to range B5-AA5. This will update the information accordingly.