Skip to content

Pycord Release Schedule #3079

@Paillat-dev

Description

@Paillat-dev

Warning

This document is a DRAFT and should not be considered official nor definitive.

Pycord Release Schedule

Status: Draft
Authors: <Paillat-dev paillat@pycord.dev>

Purpose of this document

This document aims at describing the release schedule of Pycord, and its versioning.

Pycord has, until now, never had any formal release schedule. It was mostly vibe-based, with releases happening whenever
the maintainers felt like it.

This approach, while flexible, made it difficult for users to plan their projects around Pycord's updates, and
ultimately led to significant undesirable gaps between multiple releases (e.g. 1y+ between v2.6.1 and v2.7.0, and
between v2.4.1 and v2.5.0).

Pycord follows semantic versioning, with some exceptions and guarantees as described below.

Release Guarantees

Note

For a full and up to date list of Pycord's release guarantees, please
see https://docs.pycord.dev/en/stable/version_guarantees.html.

The library follows the semantic versioning principle which means that the major version is
updated every time there is an incompatible API change. However due to the lack of guarantees on the Discord side when
it comes to breaking changes along with the fairly dynamic nature of Python it can be hard to discern what can be
considered a breaking change and what isn't.

The first thing to keep in mind is that breaking changes only apply to publicly documented functions and classes. If
it's not listed in the documentation here then it is not part of the public API and is thus bound to change. This
includes attributes that start with an underscore or functions without an underscore that are not documented.

Release Schedule

Pycord's release schedule consists of:

  • Up to three minor releases per year.
  • At least three patch releases per year.
  • At least one release candidate preceding each minor release by at least one month, with an optional second release
    candidate no later than two weeks before the minor release.
  • At least one patch release one month after each minor release.

The content of releases follows semantic versioning. The release schedule follows a quadrimestrial cycle.

At the beginning of each quadrimester, if new features are ready for release, the Minor Quadrimester Plan is
followed. Otherwise, the Patch Quadrimester Plan is followed.

Minor Quadrimester Plan:

  • Month 0: n/a
  • Month 1: Release Candidate
  • Month 2: Minor release
  • Month 3: Patch release

A second release candidate may be released no later than two weeks before the minor release if needed.

Patch Quadrimester Plan:

  • Month 0: n/a
  • Month 1: Patch release
  • Month 2: n/a
  • Month 3: Patch release

The release schedule is followed as planned. Releases include at minimum dependency updates or minor
fixes.

In the rare case that absolutely nothing is available (no dependency updates, no fixes, no changes), the release is
skipped.

In case of an emergency, such as a security issue, a patch release is made as soon as possible.
It counts as the planned patch release if it occurs during a month where a patch is already scheduled, else it is
ignored release-planning wise.

Feature Freeze

  • Minor releases: Features must be merged at least one week before the release candidate. Fixes can be merged up to
    three days before the respective Minor release. A second release candidate may be released no later than two weeks
    before the minor release.
  • Patch releases: Fixes must be merged at least three days before release.

Release Tracking

GitHub Milestones

GitHub milestones must be maintained for all upcoming releases in the current quadrimestrial cycle.

  • All milestones are created at the start of each quadrimester with target dates based on the chosen plan
  • Pull requests and issues intended for a release must be assigned to the corresponding milestone
  • Milestones are closed when the release is published
  • If a release is skipped, its milestone is closed without a release
  • All milestones include a target release date

Schedule Start Date

This release schedule officially begins with Q1 2026 (March - June), with quadrimesters aligned as follows:

  • Q1: March - June
  • Q2: July - October
  • Q3: November - February

The current cycle (Q3 2025: November 2025 - February 2026) is already following the Minor Quadrimester Plan:

  • November 2025 (Month 1): v2.7.0-rc2
  • December 2025 (Month 2): v2.7.0
  • January 2026 (Month 3): v2.7.1
  • February 2026 (Month 0): n/a

Starting March 2026 (Q1 2026), all quadrimesters follow the standard 4-month cycle as described in this document.

Roles and Responsibilities

Pycord Maintainers

At the start of each quadrimester, maintainers assess together available features and decide on the quadrimestrial
plan within the first week. Once the plan is decided, it is announced and pinned in the #discussion channel of
the Pycord Discord server.

Pycord maintainers are responsible for deciding unanimously on the release schedule and for the release process. In case
of conflicts, the decision may be escalated to the release managers.

Once a release is ready, Maintainers inform the current Release Managers.

Release Managers

The Release Managers consist of Pycord Project Managers and Project Leads. They are responsible for the release
process.
This consists of:

  • Managing the release workflow
  • Ensuring workflow completeness
  • Ensuring Announcements are made

Release Schedule Flowchart

flowchart TD
    Start(["Start of Quadrimester"]) --> Month0Start["Month 0"]
    Month0Start --> Assess{"Maintainers assess:<br>Features ready?"}
    Assess -- Yes --> MinorDecision["Minor Quadrimester"]
    Assess -- No --> PatchDecision["Patch Quadrimester"]
    MinorDecision --> Announce["Maintainers:<br>Announce in #discussion<br>Pin message"]
    PatchDecision --> Announce
    Announce --> CreateMilestones{"Maintainers:<br>Create milestones"}
    CreateMilestones -- Minor --> M_Milestones["Milestones:<br>RC, Minor, Patch"]
    CreateMilestones -- Patch --> P_Milestones["Milestones:<br>2 Patches"]
    M_Milestones --> M_Month1["Month 1:<br>Feature Freeze<br>Release RC<br>Close milestone"]
    P_Milestones --> P_Month1["Month 1:<br>Release Patch<br>Close milestone"]
    M_Month1 --> M_Month2["Month 2:<br>Release Minor<br>Close milestone"]
    P_Month1 --> P_Month2["Month 2:<br>n/a"]
    M_Month2 --> Month3["Month 3:<br>Release Patch<br>Close milestone"]
    P_Month2 --> Month3
    Month3 --> End(["End of Quadrimester"])
    style Start fill:#e1f5e1,color:#000
    style Assess fill:#fff4e1,color:#000
    style CreateMilestones fill:#fff4e1,color:#000
    style M_Month1 fill:#ffe1e1,color:#000
    style End fill:#ffe1e1,color:#000
Loading

Metadata

Metadata

Labels

documentationImprovements or additions to documentationhold: discussionThis pull request needs to be further discussed between maintainers
No fields configured for Informative.

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions