Maven GitHub Conventions

This document describes how Maven developers and contributors should use GitHub Issues and Pull Request.

GitHub Issues, Pull Request - Recommendations.

A GitHub Issue should be created to report a bug or request a new feature.

A GitHub Issue can be created to discuss of change before starting work on it. The developer mailing list can also be used to discuss proposed work.

When you provide a Pull Request - creating separate issue is not necessary as you can describe your proposition in Pull Request.

When fixing the issue by providing Pull Request, reference the issue in the commit message by #issue-number.

A GitHub Issue and Pull Request should have a label with the type, like bug, enhancement and so on. Pull Request without labels will be not categorized in Release Notes.

Closed GitHub Issue and Pull Request should have Milestone in which was resolved.

Pull Request title is used to generate Release Notes - should be similar or the same as merged commit.

We should always provide changes by Pull Request. Direct commits will be not visible in Milestones issues list nor Release Notes.

Release Notes

Only Pull Requests with status Merged will be visible in Release Notes.

We use GitHub Release Notes.

We use the Release Drafter Action to prepare Release Notes.

Default label configurations are in the maven-gh-actions-shared project.

How To Use Issue and Pull Request Details?

Assignee

Committers can assign a GitHub Issue or Pull Request to a specific committer if that person seems to be well-placed to address it.

Reviewers

We should invite persons to review for every change, even it is simply one, review can increase code quality.

Priority

For priority (equivqlent to Jira Priority), we can use GitHub Issues labels:

  • priority:trivial
  • priority:minor
  • priority:major
  • priority:critical
  • priority:blocker

Type

For GitHub Issue and Pull Requests we use labels, like:

  • bug
  • dependencies
  • documentation
  • enhancement
  • maintenance

Component/s

To assign an issue/PR to component we can use labels, like: component:name

Fix Version/s

We use GitHub Issues Milestones to assign to fix versions.

Issues and PR associated to a Milestone are publicly available, so we can use Milestone view during voting.

Further Links