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:
commit
f7010b96bd
@ -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())
|
|
@ -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>
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
52
remove-future-requirement.patch
Normal file
52
remove-future-requirement.patch
Normal 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
181
test.py
@ -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()
|
|
||||||
|
|
||||||
|
@ -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()
|
|
Loading…
Reference in New Issue
Block a user