Accepting request 1109157 from devel:languages:python

- Stop patching files that we ship directly, therefore
  * Remove patch fix-tests.patch
  * Remove patch use_unittest.patch
- Switch to pyproject, autosetup and pyunittest macros.
- Add patch remove-future-requirement.patch, remove requirement of future

OBS-URL: https://build.opensuse.org/request/show/1109157
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-ana?expand=0&rev=7
This commit is contained in:
Ana Guerrero 2023-09-06 16:58:28 +00:00 committed by Git OBS Bridge
commit f7010b96bd
6 changed files with 156 additions and 376 deletions

View File

@ -1,30 +0,0 @@
From b8338bc7a6517a57ddd1537490be8b7023617104 Mon Sep 17 00:00:00 2001
From: Daniel Garcia Moreno <daniel.garcia@suse.com>
Date: Wed, 25 Jan 2023 11:01:30 +0100
Subject: [PATCH] Fix tests: Do not test different id in test_dir
Looks like the python interpreter uses the same id if it's available, so
this test fails randomly, depending on memory management.
".../ana-0.06/test.py", line 113, in test_dir
self.assertNotEqual(old_id, id(two))
AssertionError: 140642905866320 == 140642905866320
This patch just removes the check because we cannot be sure that they
are different.
---
test.py | 1 -
1 file changed, 1 deletion(-)
diff --git a/test.py b/test.py
index 8c5f9ee..1250c34 100644
--- a/test.py
+++ b/test.py
@@ -110,7 +110,6 @@ def test_dir(self):
ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
two = A.ana_load(uuid)
self.assertEquals(uuid, two.ana_uuid)
- self.assertNotEqual(old_id, id(two))
# reset the datalayer to make sure we handle it properly
ana.set_dl(ana.DictDataLayer())

View File

@ -1,3 +1,12 @@
-------------------------------------------------------------------
Wed Sep 6 03:05:47 UTC 2023 - Steve Kowalik <steven.kowalik@suse.com>
- Stop patching files that we ship directly, therefore
* Remove patch fix-tests.patch
* Remove patch use_unittest.patch
- Switch to pyproject, autosetup and pyunittest macros.
- Add patch remove-future-requirement.patch, remove requirement of future
------------------------------------------------------------------- -------------------------------------------------------------------
Wed Jan 25 11:30:57 UTC 2023 - Daniel Garcia <daniel.garcia@suse.com> Wed Jan 25 11:30:57 UTC 2023 - Daniel Garcia <daniel.garcia@suse.com>

View File

@ -22,21 +22,18 @@ Version: 0.06
Release: 0 Release: 0
Summary: The Python "ana" module Summary: The Python "ana" module
License: BSD-2-Clause License: BSD-2-Clause
Group: Development/Languages/Python
URL: https://github.com/zardus/ana URL: https://github.com/zardus/ana
Source: https://files.pythonhosted.org/packages/source/a/ana/ana-%{version}.tar.gz Source: https://files.pythonhosted.org/packages/source/a/ana/ana-%{version}.tar.gz
# https://github.com/zardus/ana/issues/13 # https://github.com/zardus/ana/issues/13
Source2: https://raw.githubusercontent.com/zardus/ana/master/test.py Source2: test.py
Source3: https://raw.githubusercontent.com/zardus/ana/master/test_pickle.p Source3: https://raw.githubusercontent.com/zardus/ana/master/test_pickle.p
# https://github.com/zardus/ana/pull/14 # https://github.com/zardus/ana/commit/7f3c0dd8bd9ed89e3e146f934212516831147c51
Patch0: use_unittest.patch Patch0: remove-future-requirement.patch
# https://github.com/zardus/ana/pull/15 BuildRequires: %{python_module pip}
Patch1: fix-tests.patch
BuildRequires: %{python_module future}
BuildRequires: %{python_module setuptools} BuildRequires: %{python_module setuptools}
BuildRequires: %{python_module wheel}
BuildRequires: fdupes BuildRequires: fdupes
BuildRequires: python-rpm-macros BuildRequires: python-rpm-macros
Requires: python-future
BuildArch: noarch BuildArch: noarch
%python_subpackages %python_subpackages
@ -44,21 +41,19 @@ BuildArch: noarch
A Python module that provides an undocumented data layer for Python objects. A Python module that provides an undocumented data layer for Python objects.
%prep %prep
%setup -q -n ana-%{version} %autosetup -p1 -n ana-%{version}
[ -e test.py ] || cp %{SOURCE2} test.py cp %{SOURCE2} test.py
[ -e test_pickle.p ] || cp %{SOURCE3} test_pickle.p cp %{SOURCE3} test_pickle.p
%patch0
%patch1 -p1
%build %build
%python_build %pyproject_wheel
%install %install
%python_install %pyproject_install
%python_expand %fdupes %{buildroot}%{$python_sitelib} %python_expand %fdupes %{buildroot}%{$python_sitelib}
%check %check
%python_exec -m unittest discover %pyunittest discover
%files %{python_files} %files %{python_files}
%license LICENSE %license LICENSE

View File

@ -0,0 +1,52 @@
From 7f3c0dd8bd9ed89e3e146f934212516831147c51 Mon Sep 17 00:00:00 2001
From: Lumir Balhar <lbalhar@redhat.com>
Date: Mon, 31 Jul 2023 16:33:40 +0200
Subject: [PATCH] Remove dependency on future
Fixes: https://github.com/zardus/ana/issues/16
---
ana/storable.py | 8 +++-----
setup.py | 2 +-
2 files changed, 4 insertions(+), 6 deletions(-)
diff --git a/ana/storable.py b/ana/storable.py
index a11710b..37379b1 100644
--- a/ana/storable.py
+++ b/ana/storable.py
@@ -1,5 +1,3 @@
-from future.utils import iteritems
-from past.builtins import long, unicode
import uuid as uuid_module
import logging
@@ -48,11 +46,11 @@ def ana_load(cls, uuid):
def _any_to_literal(o, known_set, objects):
if o is None:
return None
- elif type(o) in (long, int, str, unicode, float, bool):
+ elif type(o) in (int, str, float, bool):
return o
elif isinstance(o, dict):
return {
- Storable._any_to_literal(k, known_set, objects):Storable._any_to_literal(v, known_set, objects) for k,v in iteritems(o)
+ Storable._any_to_literal(k, known_set, objects):Storable._any_to_literal(v, known_set, objects) for k,v in o.items()
}
elif isinstance(o, list) or isinstance(o, tuple) or isinstance(o, set):
return [ Storable._any_to_literal(e, known_set, objects) for e in o ]
@@ -108,7 +106,7 @@ def _ana_getstate(self):
return { k: getattr(self, k) for k in self._all_slots() if hasattr(self, k) }
def _ana_setstate(self, s):
- for k,v in iteritems(s):
+ for k,v in s.items():
setattr(self, k, v)
def _ana_getliteral(self):
diff --git a/setup.py b/setup.py
index f574ef5..291104b 100644
--- a/setup.py
+++ b/setup.py
@@ -1,2 +1,2 @@
from distutils.core import setup
-setup(name='ana', version='0.06', install_requires=['future'], packages=['ana'])
+setup(name='ana', version='0.06', packages=['ana'])

181
test.py
View File

@ -1,7 +1,7 @@
import os import os
import gc import gc
import ana import ana
import nose import unittest
import pickle import pickle
import logging import logging
@ -9,8 +9,6 @@ l = logging.getLogger("ana.test")
class A(ana.Storable): class A(ana.Storable):
def __init__(self, n): def __init__(self, n):
nose.tools.assert_false(hasattr(self, 'n'))
self.n = n self.n = n
l.debug("%s.__init__", self) l.debug("%s.__init__", self)
@ -28,114 +26,103 @@ class A(ana.Storable):
def _ana_getliteral(self): def _ana_getliteral(self):
return { 'n': self.n } return { 'n': self.n }
def test_simple(): class TestAna(unittest.TestCase):
ana.set_dl(ana.SimpleDataLayer()) def test_simple(self):
one = A(1) ana.set_dl(ana.SimpleDataLayer())
one.make_uuid() one = A(1)
o = pickle.dumps(one) one.make_uuid()
one_copy = pickle.loads(o) o = pickle.dumps(one)
assert one is one_copy one_copy = pickle.loads(o)
assert one is one_copy
two = A(1) two = A(1)
t = pickle.dumps(one) t = pickle.dumps(one)
two_copy = pickle.loads(t) two_copy = pickle.loads(t)
assert two_copy is not two assert two_copy is not two
assert pickle.load(open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'rb')).n == 1337 assert pickle.load(open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'rb')).n == 1337
def write_a1337(): def write_a1337(self):
a1337 = A(1337) a1337 = A(1337)
a1337.make_uuid() a1337.make_uuid()
pickle.dump(a1337, open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'w')) pickle.dump(a1337, open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'w'))
def test_dict(): def test_dict(self):
ana.set_dl(ana.DictDataLayer()) ana.set_dl(ana.DictDataLayer())
l.debug("Initializing 1") l.debug("Initializing 1")
one = A(1) one = A(1)
l.debug("Initializing 2") l.debug("Initializing 2")
two = A(2) two = A(2)
one.make_uuid() one.make_uuid()
l.debug("Copying 1") l.debug("Copying 1")
one_p = pickle.dumps(one) one_p = pickle.dumps(one)
one_copy = pickle.loads(one_p) one_copy = pickle.loads(one_p)
l.debug("Copying 2") l.debug("Copying 2")
two_p = pickle.dumps(two) two_p = pickle.dumps(two)
two_copy = pickle.loads(two_p) two_copy = pickle.loads(two_p)
nose.tools.assert_is(one_copy, one) self.assertIs(one_copy, one)
nose.tools.assert_is_not(two_copy, two) self.assertIsNot(two_copy, two)
nose.tools.assert_equal(str(two_copy), str(two)) self.assertEqual(str(two_copy), str(two))
nose.tools.assert_is(one, A.ana_load(one.ana_store())) self.assertIs(one, A.ana_load(one.ana_store()))
nose.tools.assert_is(two, A.ana_load(two.ana_store())) self.assertIs(two, A.ana_load(two.ana_store()))
two_copy2 = pickle.loads(pickle.dumps(two)) two_copy2 = pickle.loads(pickle.dumps(two))
nose.tools.assert_equal(str(two_copy2), str(two)) self.assertEqual(str(two_copy2), str(two))
l.debug("Initializing 3") l.debug("Initializing 3")
three = A(3) three = A(3)
three_str = str(three) three_str = str(three)
l.debug("Storing 3") l.debug("Storing 3")
three_uuid = three.ana_store() three_uuid = three.ana_store()
l.debug("Deleting 3") l.debug("Deleting 3")
del three del three
gc.collect() gc.collect()
nose.tools.assert_false(three_uuid in ana.get_dl().uuid_cache) self.assertFalse(three_uuid in ana.get_dl().uuid_cache)
l.debug("Loading 3") l.debug("Loading 3")
three_copy = A.ana_load(three_uuid) three_copy = A.ana_load(three_uuid)
nose.tools.assert_equal(three_copy.ana_uuid, three_uuid) #pylint:disable=no-member self.assertEqual(three_copy.ana_uuid, three_uuid) #pylint:disable=no-member
nose.tools.assert_equal(str(three_copy), three_str) self.assertEqual(str(three_copy), three_str)
known = set() known = set()
first_json = three_copy.to_literal(known) first_json = three_copy.to_literal(known)
nose.tools.assert_true(three_copy.ana_uuid in first_json['objects']) self.assertTrue(three_copy.ana_uuid in first_json['objects'])
nose.tools.assert_equal(first_json['objects'][three_copy.ana_uuid]['object']['n'], three_copy.n) self.assertEqual(first_json['objects'][three_copy.ana_uuid]['object']['n'], three_copy.n)
nose.tools.assert_equal(first_json['value']['ana_uuid'], three_copy.ana_uuid) self.assertEqual(first_json['value']['ana_uuid'], three_copy.ana_uuid)
second_json = three_copy.to_literal(known) second_json = three_copy.to_literal(known)
nose.tools.assert_false(three_copy.ana_uuid in second_json['objects']) self.assertFalse(three_copy.ana_uuid in second_json['objects'])
nose.tools.assert_equal(second_json['value']['ana_uuid'], three_copy.ana_uuid) self.assertEqual(second_json['value']['ana_uuid'], three_copy.ana_uuid)
def test_dir(): def test_dir(self):
ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana") ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
one = A(1) one = A(1)
nose.tools.assert_is(one, A.ana_load(one.ana_store())) self.assertIs(one, A.ana_load(one.ana_store()))
nose.tools.assert_true(os.path.exists("/tmp/test_ana/%s.p" % one.ana_uuid)) self.assertTrue(os.path.exists("/tmp/test_ana/%s.p" % one.ana_uuid))
uuid = one.ana_uuid uuid = one.ana_uuid
old_id = id(one) old_id = id(one)
del one del one
gc.collect() gc.collect()
ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana") ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
two = A.ana_load(uuid)
nose.tools.assert_equals(uuid, two.ana_uuid)
nose.tools.assert_not_equals(old_id, id(two))
# reset the datalayer to make sure we handle it properly
ana.set_dl(ana.DictDataLayer())
try:
two = A.ana_load(uuid) two = A.ana_load(uuid)
assert False self.assertEquals(uuid, two.ana_uuid)
except KeyError:
pass # reset the datalayer to make sure we handle it properly
two.ana_store() ana.set_dl(ana.DictDataLayer())
del two try:
three = A.ana_load(uuid) two = A.ana_load(uuid)
assert uuid, three.ana_uuid assert False
except KeyError:
pass
two.ana_store()
del two
three = A.ana_load(uuid)
assert uuid, three.ana_uuid
if __name__ == '__main__': if __name__ == '__main__':
import sys unittest.main()
logging.getLogger("ana.test").setLevel(logging.DEBUG)
logging.getLogger("ana.storable").setLevel(logging.DEBUG)
logging.getLogger("ana.datalayer").setLevel(logging.DEBUG)
logging.getLogger("ana.d").setLevel(logging.DEBUG)
if len(sys.argv) > 1:
globals()['test_%s' % sys.argv[1]]()
else:
test_simple()
test_dict()
test_dir()

View File

@ -1,233 +0,0 @@
--- test.py.orig 2020-03-25 14:52:11.172556627 +0100
+++ test.py 2020-03-25 14:41:33.347473176 +0100
@@ -1,7 +1,7 @@
import os
import gc
import ana
-import nose
+import unittest
import pickle
import logging
@@ -9,8 +9,6 @@
class A(ana.Storable):
def __init__(self, n):
- nose.tools.assert_false(hasattr(self, 'n'))
-
self.n = n
l.debug("%s.__init__", self)
@@ -28,114 +26,104 @@
def _ana_getliteral(self):
return { 'n': self.n }
-def test_simple():
- ana.set_dl(ana.SimpleDataLayer())
- one = A(1)
- one.make_uuid()
- o = pickle.dumps(one)
- one_copy = pickle.loads(o)
- assert one is one_copy
-
- two = A(1)
- t = pickle.dumps(one)
- two_copy = pickle.loads(t)
- assert two_copy is not two
-
- assert pickle.load(open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'rb')).n == 1337
-
-def write_a1337():
- a1337 = A(1337)
- a1337.make_uuid()
- pickle.dump(a1337, open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'w'))
-
-def test_dict():
- ana.set_dl(ana.DictDataLayer())
- l.debug("Initializing 1")
- one = A(1)
- l.debug("Initializing 2")
- two = A(2)
-
- one.make_uuid()
-
- l.debug("Copying 1")
- one_p = pickle.dumps(one)
- one_copy = pickle.loads(one_p)
- l.debug("Copying 2")
- two_p = pickle.dumps(two)
- two_copy = pickle.loads(two_p)
-
- nose.tools.assert_is(one_copy, one)
- nose.tools.assert_is_not(two_copy, two)
- nose.tools.assert_equal(str(two_copy), str(two))
-
- nose.tools.assert_is(one, A.ana_load(one.ana_store()))
- nose.tools.assert_is(two, A.ana_load(two.ana_store()))
-
- two_copy2 = pickle.loads(pickle.dumps(two))
- nose.tools.assert_equal(str(two_copy2), str(two))
-
- l.debug("Initializing 3")
- three = A(3)
- three_str = str(three)
- l.debug("Storing 3")
- three_uuid = three.ana_store()
- l.debug("Deleting 3")
- del three
- gc.collect()
- nose.tools.assert_false(three_uuid in ana.get_dl().uuid_cache)
- l.debug("Loading 3")
- three_copy = A.ana_load(three_uuid)
- nose.tools.assert_equal(three_copy.ana_uuid, three_uuid) #pylint:disable=no-member
- nose.tools.assert_equal(str(three_copy), three_str)
-
- known = set()
- first_json = three_copy.to_literal(known)
- nose.tools.assert_true(three_copy.ana_uuid in first_json['objects'])
- nose.tools.assert_equal(first_json['objects'][three_copy.ana_uuid]['object']['n'], three_copy.n)
- nose.tools.assert_equal(first_json['value']['ana_uuid'], three_copy.ana_uuid)
-
- second_json = three_copy.to_literal(known)
- nose.tools.assert_false(three_copy.ana_uuid in second_json['objects'])
- nose.tools.assert_equal(second_json['value']['ana_uuid'], three_copy.ana_uuid)
-
-def test_dir():
- ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
- one = A(1)
- nose.tools.assert_is(one, A.ana_load(one.ana_store()))
- nose.tools.assert_true(os.path.exists("/tmp/test_ana/%s.p" % one.ana_uuid))
-
- uuid = one.ana_uuid
- old_id = id(one)
- del one
- gc.collect()
- ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
- two = A.ana_load(uuid)
- nose.tools.assert_equals(uuid, two.ana_uuid)
- nose.tools.assert_not_equals(old_id, id(two))
-
- # reset the datalayer to make sure we handle it properly
- ana.set_dl(ana.DictDataLayer())
- try:
+class TestAna(unittest.TestCase):
+ def test_simple(self):
+ ana.set_dl(ana.SimpleDataLayer())
+ one = A(1)
+ one.make_uuid()
+ o = pickle.dumps(one)
+ one_copy = pickle.loads(o)
+ assert one is one_copy
+
+ two = A(1)
+ t = pickle.dumps(one)
+ two_copy = pickle.loads(t)
+ assert two_copy is not two
+
+ assert pickle.load(open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'rb')).n == 1337
+
+ def write_a1337(self):
+ a1337 = A(1337)
+ a1337.make_uuid()
+ pickle.dump(a1337, open(os.path.join(os.path.dirname(__file__), 'test_pickle.p'), 'w'))
+
+ def test_dict(self):
+ ana.set_dl(ana.DictDataLayer())
+ l.debug("Initializing 1")
+ one = A(1)
+ l.debug("Initializing 2")
+ two = A(2)
+
+ one.make_uuid()
+
+ l.debug("Copying 1")
+ one_p = pickle.dumps(one)
+ one_copy = pickle.loads(one_p)
+ l.debug("Copying 2")
+ two_p = pickle.dumps(two)
+ two_copy = pickle.loads(two_p)
+
+ self.assertIs(one_copy, one)
+ self.assertIsNot(two_copy, two)
+ self.assertEqual(str(two_copy), str(two))
+
+ self.assertIs(one, A.ana_load(one.ana_store()))
+ self.assertIs(two, A.ana_load(two.ana_store()))
+
+ two_copy2 = pickle.loads(pickle.dumps(two))
+ self.assertEqual(str(two_copy2), str(two))
+
+ l.debug("Initializing 3")
+ three = A(3)
+ three_str = str(three)
+ l.debug("Storing 3")
+ three_uuid = three.ana_store()
+ l.debug("Deleting 3")
+ del three
+ gc.collect()
+ self.assertFalse(three_uuid in ana.get_dl().uuid_cache)
+ l.debug("Loading 3")
+ three_copy = A.ana_load(three_uuid)
+ self.assertEqual(three_copy.ana_uuid, three_uuid) #pylint:disable=no-member
+ self.assertEqual(str(three_copy), three_str)
+
+ known = set()
+ first_json = three_copy.to_literal(known)
+ self.assertTrue(three_copy.ana_uuid in first_json['objects'])
+ self.assertEqual(first_json['objects'][three_copy.ana_uuid]['object']['n'], three_copy.n)
+ self.assertEqual(first_json['value']['ana_uuid'], three_copy.ana_uuid)
+
+ second_json = three_copy.to_literal(known)
+ self.assertFalse(three_copy.ana_uuid in second_json['objects'])
+ self.assertEqual(second_json['value']['ana_uuid'], three_copy.ana_uuid)
+
+ def test_dir(self):
+ ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
+ one = A(1)
+ self.assertIs(one, A.ana_load(one.ana_store()))
+ self.assertTrue(os.path.exists("/tmp/test_ana/%s.p" % one.ana_uuid))
+
+ uuid = one.ana_uuid
+ old_id = id(one)
+ del one
+ gc.collect()
+ ana.dl = ana.DirDataLayer(pickle_dir="/tmp/test_ana")
two = A.ana_load(uuid)
- assert False
- except KeyError:
- pass
- two.ana_store()
- del two
- three = A.ana_load(uuid)
- assert uuid, three.ana_uuid
+ self.assertEquals(uuid, two.ana_uuid)
+ self.assertNotEqual(old_id, id(two))
-if __name__ == '__main__':
- import sys
- logging.getLogger("ana.test").setLevel(logging.DEBUG)
- logging.getLogger("ana.storable").setLevel(logging.DEBUG)
- logging.getLogger("ana.datalayer").setLevel(logging.DEBUG)
- logging.getLogger("ana.d").setLevel(logging.DEBUG)
-
- if len(sys.argv) > 1:
- globals()['test_%s' % sys.argv[1]]()
- else:
- test_simple()
- test_dict()
- test_dir()
+ # reset the datalayer to make sure we handle it properly
+ ana.set_dl(ana.DictDataLayer())
+ try:
+ two = A.ana_load(uuid)
+ assert False
+ except KeyError:
+ pass
+ two.ana_store()
+ del two
+ three = A.ana_load(uuid)
+ assert uuid, three.ana_uuid
+
+if __name__ == '__main__':
+ unittest.main()