Skip to content

Conversation

@terencehonles
Copy link
Contributor

@terencehonles terencehonles commented May 2, 2025

Description of change

This change adds equality and hashability to Retry and backoff classes.

This broke in DjangoRQ (fixed) after #3622 / #3614 and I provided a workaround in rq/django-rq#706, but this allows other downstream libraries to compare two retry instances.

Pull Request check-list

Please make sure to review and check all of these items:

  • Do tests and lints pass with this change?
  • Do the CI tests pass with this change (enable it first in your forked repo and wait for the github action build to finish)?
  • Is the new or changed code fully tested?
  • Is a documentation update included (if this change modifies existing APIs, or introduces new ones)?
  • Is there an example added to the examples folder (if applicable)?
  • Was the change added to CHANGES file?

NOTE: these things are not required to open a PR and can be done
afterwards / while the PR is open.

Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

This PR adds equality and hashability methods to the Retry and various backoff classes to support reliable comparisons between retry instances in downstream libraries.

  • Introduces eq and hash for Retry and multiple backoff classes.
  • Augments the test suite with new test cases to validate equality/hashability behavior.

Reviewed Changes

Copilot reviewed 3 out of 3 changed files in this pull request and generated 3 comments.

File Description
tests/test_retry.py Adds tests validating equality and hashability of Retry instances.
redis/retry.py Implements eq and hash methods for the Retry class.
redis/backoff.py Adds equality and hashability implementations for several backoff types.
@terencehonles terencehonles force-pushed the add-equality-and-hashability-to-retry-classes branch 4 times, most recently from 464721d to 5b9fe2e Compare May 2, 2025 12:35
redis/backoff.py Outdated
return (
self._base == other._base
and self._cap == other._cap
and self._previous_backoff == other._previous_backoff
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that you should not compare the _previous_backoff fields- they represent the progress/state of the objects, not the configuration. For example, it is also not included in the hash of the object.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sure, I wasn't sure if the current state should affect it, but guess that's not usually what someone might care about

@terencehonles terencehonles force-pushed the add-equality-and-hashability-to-retry-classes branch from 31e489d to bd59a8c Compare May 6, 2025 06:10
Copy link
Collaborator

@petyaslavova petyaslavova left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM.

@petyaslavova petyaslavova merged commit a1f3cab into redis:master May 7, 2025
37 checks passed
@petyaslavova petyaslavova added the feature New feature label May 7, 2025
@terencehonles terencehonles deleted the add-equality-and-hashability-to-retry-classes branch May 8, 2025 16:22
@selwin
Copy link

selwin commented May 10, 2025

@petyaslavova may I know if a patch release is expected soon? This causes RQ to break on Redis-py 6.0.

@petyaslavova
Copy link
Collaborator

@petyaslavova may I know if a patch release is expected soon? This causes RQ to break on Redis-py 6.0.

Hi @selwin, soon there will be a 6.1.0 release- the fix will be included in this upcoming release.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

feature New feature

3 participants