README.md
1<!---
2Copyright (C) 2018 and later: Unicode, Inc. and others.
3License & terms of use: http://www.unicode.org/copyright.html
4-->
5
6# Commit Checker Tool
7
8This tool checks the ICU Git repository against the ICU Jira issue tracker to ensure that the two are consistent with one another.
9
10Author: Shane Carr
11
12## Installation
13
14Install `pipenv` globally:
15
16 $ sudo pip3 install pipenv
17
18Install this project's dependencies locally:
19
20 $ pipenv install
21
22Optional: save your Jira credentials in a `.env` file in this directory:
23
24 JIRA_USERNAME=hello@example.com
25 JIRA_PASSWORD=world
26
27This is required if you want to process sensitive tickets. Note: JIRA_PASSWORD needs to be an API Token generated according to the following instructions:
28
29https://confluence.atlassian.com/cloud/api-tokens-938839638.html
30
31## Usage
32
33Make sure you have updated your repository:
34
35 $ git fetch --tags upstream
36
37Run the tool and save the result into REPORT.md; set fixVersion to the upcoming ICU version, and take the revision range between the previous release and the tip for the upcoming release:
38
39 $ pipenv run python3 check.py \
40 --jira-query "project=ICU AND fixVersion=64.1" \
41 --rev-range "release-63-1..upstream/maint/maint-64"
42 > REPORT.md
43
44If the maintenance branch hasn't been cut yet, use upstream/main as the tip:
45
46 --rev-range "release-64-2..upstream/main"
47
48Note 1: These examples assume that your remote named "upstream" points to unicode-org/icu, the source of truth.
49
50Note 2: Please change the previous-release tag (release-63-1, release-64-2, etc) to the correct version at the time you run the tool!
51
52### Preview the Report
53
54To preview the report, render the Markdown file in your favorite Markdown preview tool, like grip:
55
56 $ pip3 install grip
57 $ grip REPORT.md
58 * Running on http://localhost:6419/ (Press CTRL+C to quit)
59
60### Sending for Review
61
62Before sending the report to ICU-TC, do some basic cleanup yourself by adjusting fix versions and resolutions on Jira issues.
63
64- Tickets with commits should be closed as Fixed, and fixed tickets without commits should be closed as Fixed by Other Ticket. These tickets should have a fix version.
65- Tickets closed for any other reason, such as Duplicate, should not have a fix version. Semantically, duplicate tickets inherit the fix version from the ticket to which they are duplicated.
66
67It should be possible to clear the first two sections of the report simply by correcting the ticket resolutions and fix versions in Jira.
68
69When ready, create a branch and push to your fork so others can view the report easily. Team members should close issues they own that are correctly fixed. Re-generate the report periodically until it comes back clean.
70
71Note: REPORT.md is not intended to be merged back into main.
72