Skip to content

Commit

Permalink
Add onboarding documentation for the Release Team
Browse files Browse the repository at this point in the history
Signed-off-by: Furkat Gofurov <[email protected]>
  • Loading branch information
furkatgofurov7 committed Oct 20, 2023
1 parent a36712e commit d5081aa
Show file tree
Hide file tree
Showing 4 changed files with 65 additions and 3 deletions.
4 changes: 2 additions & 2 deletions docs/release/release-tasks.md
Original file line number Diff line number Diff line change
Expand Up @@ -418,9 +418,9 @@ TODO: Right now we don't have a template for this message but the Comms Team wil
* Responsibility for the quality of the release
* Continuously monitor CI signal, so a release can be cut at any time
* Add CI signal for new release branches
* Bug Triage:
* Bug Triage:
* Make sure blocking issues and bugs are triaged and dealt with in a timely fashion
* Automation
* Automation:
* Maintain and improve release automation, tooling & related developer docs
### Tasks
Expand Down
61 changes: 61 additions & 0 deletions docs/release/release-team-onboarding.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->

- [Onboarding Notes for Release Team](#onboarding-notes-for-release-team)
- [Overview](#overview)
- [Release Lead Team](#release-lead-team)
- [Comms Lead Team](#comms-lead-team)
- [CI Signal Lead Team](#ci-signal-lead-team)

<!-- END doctoc generated TOC please keep comment here to allow auto update -->

# Onboarding Notes for Release Team

## Overview

Welcome to the Cluster API Release Team onboarding documentation!

As a member of the Release Team, you play a crucial role in helping to ensure project releases
are delivered smoothly and in a timely manner. While there are specific responsibilities for each sub-team within
the Release Team, below are some general notes that every member of the Release Team might benefit by going
through at the beginning of the cycle:

- Slack:
- Most discussions related CAPI Release topics happens in the #cluster-api channel on the Kubernetes Slack. If you need access to the Kubernetes Slack, please visit http://slack.k8s.io/.
- Kubernetes SIG membership:
- Try to become an official member of the Kubernetes SIG, if possible. More information on the membership and requirements can be found [here](https://github.com/kubernetes-sigs/cluster-api/blob/main/docs/release/release-team.md#cluster-api-release-team-vs-kuberneteskubernetes-sig-membership).
- Familiarize yourself with the Release Process:
- Review the release [tasks document](../release/release-tasks.md) which explains the responsibilities and tasks for each role within the release team.
- Check the Release Timeline:
- Go through the [release timeline](../release/releases) of the release cycle you are involved in (i.e checkout `release-1.6.md` if you are part of the 1.6 cycle release team) to better understand the key milestones and deadlines.

Now, let's dive into the specific onboarding notes for each sub-team below.

### Release Lead Team

- Explore CI Setup and Tools:
- Gain some insights into how CI is setup in the Cluster API and tools used. You can check out CI Team onboarding [notes](#ci-signal-lead-team) for more details.
- Learn about Release Notes Generation:
- Get to know how the release notes generation tools works.
- Review the onboarding notes for both the Comms and CI Lead teams:
- Check out the onboarding notes of [Comms](#comms-lead-team) and [CI Signal](#ci-signal-lead-team) teams.

### Comms Lead Team

- Understand Release Process:
- Get to know how project's release process works.
- Walk through the [release note generation process](../release/release-tasks.md#create-pr-for-release-notes) and try to generate notes by yourself. This is the most important process the comms team is in charge of.
- Familiarize yourself with the release notes tool [code](https://github.com/kubernetes-sigs/cluster-api/tree/main/hack/tools/release). You'll probably need to update this code during the release cycle to cover new cases or add new features.
- Documentation familiarity:
- Explore project's documentation and start learning how to update and maintain it.
- Communication channels:
- Learn about project's primary communication channels, including Slack, mailing list and office hours. Try to understand how information is distributed and how to use them effectively for announcements, updates and discussions related to the release cycle.

### CI Signal Lead Team

- Start by gaining a general understanding of GitHub labels and how to find issues and pull requests for the current milestone.
- Familiarize yourself with Prow commands: The Cluster API project utilizes [Prow](https://docs.prow.k8s.io/docs/overview/) to manage CI automation. Issues and PRs are categorized by applying specific list of area labels, which helps in prioritization of that specific issue/PR during the release cycle or release process. Learn more about the available [labels](https://github.com/kubernetes/test-infra/blob/master/label_sync/labels.md#labels-that-apply-to-kubernetes-sigscluster-api-for-both-issues-and-prs) and prow [commands](https://prow.k8s.io/command-help).
- Take a look at [TestGrid](https://testgrid.k8s.io/sig-cluster-lifecycle-cluster-api#Summary), an interactive dashboard for visualizing the CI job results of the project in a grid format!
- Examine the [CI jobs](https://github.com/kubernetes/test-infra/tree/master/config/jobs/kubernetes-sigs/cluster-api) in the test-infra repository. These jobs are defined in YAML and represent various job types, such as periodics and presubmits, that we run in the project. You can also find dedicated [notes](https://cluster-api.sigs.k8s.io/reference/jobs) for them in the book.
- Explore [k8s-triage](https://storage.googleapis.com/k8s-triage/index.html?job=periodic-cluster-api-*), a tool that identifies groups of similar test failures across all jobs.
- Experiment with running [end-to-end tests](https://cluster-api.sigs.k8s.io/developer/testing#running-the-end-to-end-tests-locally) on your local machine to gain a better understanding of the tests and build a confidence debugging CI issues.
1 change: 1 addition & 0 deletions docs/release/release-team.md
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,7 @@ Before you volunteer to be part of a CAPI release team, please make certain that

## Suggestions for Team Leads

* In the first week of the release cycle, organize an onboarding session with shadows of your team (i.e CI Lead with CI team shadows) to go over the general responsibilities and expectations.
* Clearly communicate with the team shadows you are responsible for, that the majority of the work during the release cycle will be a collaborative effort.
* Establish an ownership rotation policy in consultation with respective team members.
* Provide opportunities for team members to take the lead in cutting a release within the cycle, based on feasibility.
Expand Down
2 changes: 1 addition & 1 deletion hack/generate-doctoc.sh
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,4 @@ if [[ -z "$(command -v doctoc)" ]]; then
exit 0
fi

doctoc ./CONTRIBUTING.md docs/release/release-tasks.md docs/scope-and-objectives.md docs/staging-use-cases.md docs/proposals
doctoc ./CONTRIBUTING.md docs/release/release-tasks.md docs/release/release-team-onboarding.md docs/scope-and-objectives.md docs/staging-use-cases.md docs/proposals

0 comments on commit d5081aa

Please sign in to comment.