From 73d37cf0e21056b3d9166489198956c1acc7fa5b Mon Sep 17 00:00:00 2001 From: Furkat Gofurov Date: Fri, 13 Oct 2023 17:19:35 +0300 Subject: [PATCH] Add RT sub team specific onboarding notes to release tasks Signed-off-by: Furkat Gofurov --- docs/release/release-tasks.md | 4 +- docs/release/release-team-onboarding.md | 60 +++++++++++++++++++++++++ docs/release/release-team.md | 1 + hack/generate-doctoc.sh | 2 +- 4 files changed, 64 insertions(+), 3 deletions(-) create mode 100644 docs/release/release-team-onboarding.md diff --git a/docs/release/release-tasks.md b/docs/release/release-tasks.md index 6d75b2434bfa..896cd1e78231 100644 --- a/docs/release/release-tasks.md +++ b/docs/release/release-tasks.md @@ -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 diff --git a/docs/release/release-team-onboarding.md b/docs/release/release-team-onboarding.md new file mode 100644 index 000000000000..24f8ed2913fc --- /dev/null +++ b/docs/release/release-team-onboarding.md @@ -0,0 +1,60 @@ + + +**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)* + +- [Onboarding Notes for Release Team Shadows](#onboarding-notes-for-release-team-shadows) + - [Overview](#overview) + - [Release Lead Shadows Team](#release-lead-shadows-team) + - [Comms Lead Shadows Team](#comms-lead-shadows-team) + - [CI Signal Lead Shadows Team](#ci-signal-lead-shadows-team) + + + +# Onboarding Notes for Release Team Shadows + +## Overview + +Welcome to the Cluster API Release Team Shadows onboarding documentation! + +As a member of the Release Team and Shadow, 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 Shadows, below are some general notes that every member of the Releease 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 Shadows 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-shadows-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 Shadows teams: + - Check out the onboarding notes of [Comms](#comms-lead-shadows-team) and CI Signal(#ci-signal-lead-shadows-team) teams. + +### Comms Lead Shadows Team + +- Understand Release Process: + - Familiarize yourself with project's release process and the [tool](https://github.com/kubernetes-sigs/cluster-api/tree/main/hack/tools/release) used for generating release notes. +- 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 distgributed and how to use them effectively for announcements, updates and discussions related to the release cycle. + +### CI Signal Lead Shadows 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. \ No newline at end of file diff --git a/docs/release/release-team.md b/docs/release/release-team.md index 778a0f910106..76480ea095ee 100644 --- a/docs/release/release-team.md +++ b/docs/release/release-team.md @@ -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. diff --git a/hack/generate-doctoc.sh b/hack/generate-doctoc.sh index 4e0372e2ed1c..ddd26e3d6768 100755 --- a/hack/generate-doctoc.sh +++ b/hack/generate-doctoc.sh @@ -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