Skip to content

Latest commit

 

History

History
85 lines (57 loc) · 4.32 KB

EXCEPTIONS.md

File metadata and controls

85 lines (57 loc) · 4.32 KB

Exceptions to Milestone Enhancement Complete dates

For minor (1.x) milestones, the Kubernetes project has enhancement complete dates (hitting enhancement complete is all enhancement LGTMed and in submit queue with tests written) after which no new enhancements are accepted. Since minor releases come approximately quarterly, missing a enhancement complete date by just one day can mean that enhancement takes an additional 3 months to be released.

While the enhancement complete milestone dates are published well in advance, and the default is that missing the date means your enhancement will be part of the next milestone, there may be cases where an exception makes sense.

Exception Criteria

Exceptions will be granted on the basis of risk and length of exception required.

The enhancement coming in late should represent a low risk to the Kubernetes system - it should not risk other areas of the code, and it should itself be well contained and tested.

An issue must be opened for the enhancement in the enhancements repo.

The length of exception needed should be on the order of days, not weeks. If there are 3 PRs in and 1 still waiting review, that's a much stronger case than a enhancement that doesn't have any PRs out yet.

Requesting an exception

Enhancement Owners

To file for an exception, please fill out the questions below:

  • Enhancement name:
  • Enhancement status (alpha/beta/stable):
  • SIG:
  • k/enhancements repo issue #:
  • PR #’s:
  • Additional time needed (in days):
  • Reason this enhancement is critical for this milestone:
  • Risks from adding code late: (to k8s stability, testing, etc.)
  • Risks from cutting enhancement: (partial implementation, critical customer usecase, etc.)

Email them to:

[You should have very high confidence on the “additional time needed” number - we will not grant multiple exceptions for a enhancement.]

Exceptions after enhancements freeze: If your issue was removed during the enhancements freeze please file an exception at your earlierst convinence. All requests will be reviewed and either approved or rejected as they come in. The release team will be responsible for approving or rejecting exceptions based on the questions above.

Exceptoins after code freeze: Requests for exceptions must be submitted before the first milestone burn down meeting. All requests for exception will be reviewed and either approved or rejected during the first meeting. The release team will be responsible for approving or rejecting exceptions based on the questions above.

Information about the current release can be found in the relevant release directory:

Once an exception is approved, it should be broadcast broadly: send an email with the data and approval to kubernetes-dev@ and your SIG group, then follow up with a reply to that email once the enhancement is completed.

Enhancement Lead

After exceptions have been reviewed, the Enhancements Lead should create an exceptions.yaml file in the current release's directory e.g., release-1.11/exceptions.yaml.

exceptions.yaml should be formatted as follows:

# Exceptions to Code Freeze requested in 1.13
# Google Group: https://groups.google.com/forum/#!topic/kubernetes-milestone-burndown
# Release Team Lead: Aishwarya Sundar (@AishSundar)

- name: "Update Istio addon manifest"
  issue: "https://github.com/kubernetes/kubernetes/issues/64563"
  date_requested: 2018-10-24
  date_reviewed: 2018-10-24
  thread: "https://groups.google.com/forum/#!topic/kubernetes-milestone-burndown/68ivj9MGBdU"
  pull_requests:
  - "https://github.com/kubernetes/kubernetes/pull/64537"
  status: "approved"

- name: "Implement IPVS-based in-cluster service load balancing"
  issue: "https://github.com/kubernetes/enhancements/issues/265"
  date_requested: 2018-10-24
  date_reviewed: 2018-10-24
  thread: "https://groups.google.com/forum/#!topic/kubernetes-milestone-burndown/MJrcqkLAcn0"
  pull_requests:
  - "https://github.com/kubernetes/kubernetes/pull/58442"
  status: "approved"