From 94dcb33b15dd7963247e078bec97b74063f3ae40 Mon Sep 17 00:00:00 2001 From: Rust Saiargaliev Date: Fri, 25 Oct 2024 10:00:01 +0200 Subject: [PATCH] Fix #656 -- Add Python 3.13 support `threading.Thread` received a new `_handle` attribute in Python 3.13, which clashes with dramatiq's `_CtypesTimeoutManager(Thread)` class. This commit renames the dramatiq method to resolve the conflict. It also adds Python 3.13 to CI and package classification --- .github/workflows/push.yml | 4 ++-- .github/workflows/release.yml | 2 +- dramatiq/middleware/time_limit.py | 4 ++-- setup.py | 1 + 4 files changed, 6 insertions(+), 5 deletions(-) diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml index 70fc93cf..2f16212f 100644 --- a/.github/workflows/push.yml +++ b/.github/workflows/push.yml @@ -8,7 +8,7 @@ jobs: - uses: actions/checkout@master - uses: actions/setup-python@v4 with: - python-version: "3.12" + python-version: "3.13" - run: | sudo apt-get update sudo apt-get remove libhashkit2 libmemcached11 || true @@ -23,7 +23,7 @@ jobs: fail-fast: false matrix: os: ["ubuntu-20.04"] - python: ["3.8", "3.9", "3.10", "3.11", "3.12"] + python: ["3.8", "3.9", "3.10", "3.11", "3.12", "3.13"] concurrency: ["cpython", "gevent"] runs-on: ${{ matrix.os }} diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 0b5047cd..ddb10411 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -12,7 +12,7 @@ jobs: - uses: actions/checkout@v3 - uses: actions/setup-python@v4 with: - python-version: "3.12" + python-version: "3.13" - name: Install dependencies run: python -m pip install build diff --git a/dramatiq/middleware/time_limit.py b/dramatiq/middleware/time_limit.py index 05cd0d38..c0352108 100644 --- a/dramatiq/middleware/time_limit.py +++ b/dramatiq/middleware/time_limit.py @@ -94,7 +94,7 @@ def __init__(self, interval, logger=None): self.logger = logger or get_logger(__name__, type(self)) self.mu = threading.RLock() - def _handle(self): + def _handle_deadlines(self): current_time = monotonic() threads_to_kill = [] with self.mu: @@ -110,7 +110,7 @@ def _handle(self): def run(self): while True: try: - self._handle() + self._handle_deadlines() except Exception: # pragma: no cover self.logger.exception("Unhandled error while running the time limit handler.") diff --git a/setup.py b/setup.py index 83ac55c6..06c3c69f 100644 --- a/setup.py +++ b/setup.py @@ -126,6 +126,7 @@ def rel(*xs): "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", + "Programming Language :: Python :: 3.13", "Programming Language :: Python :: 3 :: Only", "Topic :: System :: Distributed Computing", "License :: OSI Approved :: GNU Lesser General Public License v3 or later (LGPLv3+)",