17
0

2 Commits

Author SHA256 Message Date
dd4ca3ebc8 Accepting request 1304294 from devel:languages:python
- Drop patches:
  * freezegun-skip.patch
  * python311.patch
- update to 2.0.1:
  * Via python_requires specifies that cached_property is for Python
    version 3.8 or higher
  * Officiall drop support for Python 2.6
- 2.0.0 (2024-10-25)
  * Remove support for Python versions < 3.8
  * Add formal support for Python versions up to 3.13
  * Switch to Markdown for docs
  * Migrate from black to ruff

OBS-URL: https://build.opensuse.org/request/show/1304294
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-cached-property?expand=0&rev=14
2025-09-14 16:49:15 +00:00
61353c5cf7 - Drop patches:
* freezegun-skip.patch
  * python311.patch
- update to 2.0.1:
  * Via python_requires specifies that cached_property is for Python
    version 3.8 or higher
  * Officiall drop support for Python 2.6
- 2.0.0 (2024-10-25)
  * Remove support for Python versions < 3.8
  * Add formal support for Python versions up to 3.13
  * Switch to Markdown for docs
  * Migrate from black to ruff

OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-cached-property?expand=0&rev=28
2025-09-12 11:25:47 +00:00
6 changed files with 24 additions and 133 deletions

Binary file not shown.

View File

@@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:484d617105e3ee0e4f1f58725e72a8ef9e93deee462222dbd51cd91230897641
size 10574

View File

@@ -1,14 +0,0 @@
---
tests/test_cached_property.py | 1 +
1 file changed, 1 insertion(+)
--- a/tests/test_cached_property.py
+++ b/tests/test_cached_property.py
@@ -188,6 +188,7 @@ class TestCachedPropertyWithTTL(TestCach
self.assert_cached(check, 2)
self.assert_cached(check, 2)
+ @unittest.skip("new freezegun breaks behaviour of this test")
def test_threads_ttl_expiry(self):
Check = CheckFactory(self.cached_property_factory(ttl=100000), threadsafe=True)
check = Check()

View File

@@ -1,3 +1,19 @@
-------------------------------------------------------------------
Fri Sep 12 11:24:20 UTC 2025 - Daniel Garcia <daniel.garcia@suse.com>
- Drop patches:
* freezegun-skip.patch
* python311.patch
- update to 2.0.1:
* Via python_requires specifies that cached_property is for Python
version 3.8 or higher
* Officiall drop support for Python 2.6
- 2.0.0 (2024-10-25)
* Remove support for Python versions < 3.8
* Add formal support for Python versions up to 3.13
* Switch to Markdown for docs
* Migrate from black to ruff
-------------------------------------------------------------------
Thu May 15 12:13:24 UTC 2025 - Markéta Machová <mmachova@suse.com>

View File

@@ -1,7 +1,7 @@
#
# spec file for package python-cached-property
#
# Copyright (c) 2025 SUSE LLC
# Copyright (c) 2025 SUSE LLC and contributors
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -18,18 +18,13 @@
%{?sle15_python_module_pythons}
Name: python-cached-property
Version: 1.5.2
Version: 2.0.1
Release: 0
Summary: A decorator for caching properties in classes
License: BSD-3-Clause
Group: Development/Libraries/Python
URL: https://github.com/pydanny/cached-property
Source: https://files.pythonhosted.org/packages/source/c/cached-property/cached-property-%{version}.tar.gz
# PATCH-FIX-UPSTREAM skip test that rely on wrong freezegun behaviour
# https://github.com/pydanny/cached-property/pull/125
Patch0: freezegun-skip.patch
# PATCH-FIX-UPSTREAM Don't use asyncio.coroutine if it's not available -- https://github.com/pydanny/cached-property/pull/267
Patch1: python311.patch
Source: https://files.pythonhosted.org/packages/source/c/cached-property/cached_property-%{version}.tar.gz
BuildRequires: %{python_module freezegun}
BuildRequires: %{python_module pip}
BuildRequires: %{python_module pytest}
@@ -46,7 +41,7 @@ computational expensive properties quick and easy and it works in Python 2
and 3.
%prep
%autosetup -p1 -n cached-property-%{version}
%autosetup -p1 -n cached_property-%{version}
%build
%pyproject_wheel
@@ -60,7 +55,7 @@ and 3.
%files %{python_files}
%license LICENSE
%doc AUTHORS.rst README.rst HISTORY.rst
%doc AUTHORS.md README.md HISTORY.md
%{python_sitelib}/cached[-_]property.py
%{python_sitelib}/cached[-_]property-%{version}*-info
%pycache_only %{python_sitelib}/__pycache__/cached[-_]property*

View File

@@ -1,106 +0,0 @@
From 297031687679762849dedeaf24aa3a19116f095b Mon Sep 17 00:00:00 2001
From: Petr Viktorin <encukou@gmail.com>
Date: Thu, 2 Dec 2021 11:26:20 +0100
Subject: [PATCH 1/2] Don't use asyncio.coroutinefunction if it's not available
Python 3.11 drops the deprecated @asyncio.coroutine and
asyncio.iscoroutinefunction.
Using a wrapper with @asyncio.coroutine in __get__ wasn't
necessary (the future from asyncio.ensure_future is awaitable,
and the wrapper doesn't do anything asynchronous), so the
logic can be simplified to just call asyncio.ensure_future
(to schedule the task and store the result when it's
available).
Tests for @asyncio.coroutine are skipped on 3.11+.
An unnecessary call to asyncio.coroutine in tests is
removed: it's not necessary to call this for `async def`
functions.
---
cached_property.py | 24 +++++++++++-------------
conftest.py | 8 ++++----
tests/test_async_cached_property.py | 3 +--
3 files changed, 16 insertions(+), 19 deletions(-)
--- a/cached_property.py
+++ b/cached_property.py
@@ -13,6 +13,12 @@ try:
import asyncio
except (ImportError, SyntaxError):
asyncio = None
+if asyncio:
+ try:
+ iscoroutinefunction = asyncio.iscoroutinefunction
+ except AttributeError:
+ # Python 3.11: @asyncio.coroutine was removed
+ from inspect import iscoroutinefunction
class cached_property(object):
@@ -30,22 +36,14 @@ class cached_property(object):
if obj is None:
return self
- if asyncio and asyncio.iscoroutinefunction(self.func):
- return self._wrap_in_coroutine(obj)
+ if asyncio and iscoroutinefunction(self.func):
+ value = asyncio.ensure_future(self.func(obj))
+ else:
+ value = self.func(obj)
- value = obj.__dict__[self.func.__name__] = self.func(obj)
+ obj.__dict__[self.func.__name__] = value
return value
- def _wrap_in_coroutine(self, obj):
- @wraps(obj)
- @asyncio.coroutine
- def wrapper():
- future = asyncio.ensure_future(self.func(obj))
- obj.__dict__[self.func.__name__] = future
- return future
-
- return wrapper()
-
class threaded_cached_property(object):
"""
--- a/conftest.py
+++ b/conftest.py
@@ -1,4 +1,3 @@
-
import sys
# Whether "import asyncio" works
@@ -7,13 +6,14 @@ has_asyncio = sys.version_info[0] == 3 a
# Whether the async and await keywords work
has_async_await = sys.version_info[0] == 3 and sys.version_info[1] >= 5
+# Whether "from asyncio import coroutine" *fails*
+dropped_asyncio_coroutine = sys.version_info[0] == 3 and sys.version_info[1] >= 11
-print("conftest.py", has_asyncio, has_async_await)
-
+print("conftest.py", has_asyncio, has_async_await, dropped_asyncio_coroutine)
collect_ignore = []
-if not has_asyncio:
+if not has_asyncio or dropped_asyncio_coroutine:
collect_ignore.append("tests/test_coroutine_cached_property.py")
if not has_async_await:
--- a/tests/test_async_cached_property.py
+++ b/tests/test_async_cached_property.py
@@ -9,8 +9,7 @@ import cached_property
def unittest_run_loop(f):
def wrapper(*args, **kwargs):
- coro = asyncio.coroutine(f)
- future = coro(*args, **kwargs)
+ future = f(*args, **kwargs)
loop = asyncio.get_event_loop()
loop.run_until_complete(future)