Blame SOURCES/0002-Empty-dict-created-by-_by_lang-in-python-api-causes-segfault.patch

1dfe7b
From 257df5670310775a9c279f5f34e3d088966759b1 Mon Sep 17 00:00:00 2001
1dfe7b
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
1dfe7b
Date: Mon, 7 Oct 2019 12:14:22 +0200
1dfe7b
Subject: [PATCH 1/3] Update couple of tests
1dfe7b
1dfe7b
- list indices cannot by of type float
1dfe7b
- remove unnecessary print
1dfe7b
- update print with parenthesis which are now required in python
1dfe7b
---
1dfe7b
 libcomps/src/python/tests/__test.py           | 2 +-
1dfe7b
 libcomps/src/python/tests/test_libcomps.py    | 1 -
1dfe7b
 libcomps/src/python/tests/test_merge_comps.py | 4 ++--
1dfe7b
 3 files changed, 3 insertions(+), 4 deletions(-)
1dfe7b
1dfe7b
diff --git a/libcomps/src/python/tests/__test.py b/libcomps/src/python/tests/__test.py
1dfe7b
index c9b4dd4..c7529f3 100644
1dfe7b
--- a/libcomps/src/python/tests/__test.py
1dfe7b
+++ b/libcomps/src/python/tests/__test.py
1dfe7b
@@ -225,7 +225,7 @@ def test_union3(self):
1dfe7b
     def test_hash(self):
1dfe7b
         s = set()
1dfe7b
         for x in range(6):
1dfe7b
-            s.add(self.obj_constructor(**self.obj_data[x/2]))
1dfe7b
+            s.add(self.obj_constructor(**self.obj_data[int(x/2)]))
1dfe7b
         self.assertTrue(len(s) == 3)
1dfe7b
         self.assertTrue(hash(self.obj_constructor(**self.obj_data[0])) ==\
1dfe7b
                         hash(self.obj_constructor(**self.obj_data[0])))
1dfe7b
diff --git a/libcomps/src/python/tests/test_libcomps.py b/libcomps/src/python/tests/test_libcomps.py
1dfe7b
index 2a18984..71311ef 100755
1dfe7b
--- a/libcomps/src/python/tests/test_libcomps.py
1dfe7b
+++ b/libcomps/src/python/tests/test_libcomps.py
1dfe7b
@@ -19,7 +19,6 @@
1dfe7b
 class TestLibcomps(unittest.TestCase):
1dfe7b
 
1dfe7b
     def setUp(self):
1dfe7b
-        print (dir(libcomps))
1dfe7b
         self.comps = libcomps.Comps()
1dfe7b
         self.comps.fromxml_f("comps/comps-f21.xml")
1dfe7b
         self.tmp_dir = tempfile.mkdtemp()
1dfe7b
diff --git a/libcomps/src/python/tests/test_merge_comps.py b/libcomps/src/python/tests/test_merge_comps.py
1dfe7b
index beef2cf..73e743f 100755
1dfe7b
--- a/libcomps/src/python/tests/test_merge_comps.py
1dfe7b
+++ b/libcomps/src/python/tests/test_merge_comps.py
1dfe7b
@@ -7,10 +7,10 @@
1dfe7b
 
1dfe7b
 try:
1dfe7b
     import _libpycomps as libcomps
1dfe7b
-    print "local tests"
1dfe7b
+    print("local tests")
1dfe7b
 except ImportError:
1dfe7b
     import libcomps
1dfe7b
-    print "global tests"
1dfe7b
+    print("global tests")
1dfe7b
 
1dfe7b
 
1dfe7b
 class TestMergeComps(unittest.TestCase):
1dfe7b
1dfe7b
From 1b7add27595b12b9f47e54c3e5f1bda2177da346 Mon Sep 17 00:00:00 2001
1dfe7b
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
1dfe7b
Date: Mon, 7 Oct 2019 12:50:21 +0200
1dfe7b
Subject: [PATCH 2/3] Fix segfault when converting empty dict to string
1dfe7b
 (RhBug:1757959)
1dfe7b
1dfe7b
Handle all elements in single loop consistently, instead of handling
1dfe7b
last element separately which caused problems with empty dictionary.
1dfe7b
1dfe7b
https://bugzilla.redhat.com/show_bug.cgi?id=1757959
1dfe7b
---
1dfe7b
 libcomps/src/python/src/pycomps_dict.c | 20 +-------------------
1dfe7b
 1 file changed, 1 insertion(+), 19 deletions(-)
1dfe7b
1dfe7b
diff --git a/libcomps/src/python/src/pycomps_dict.c b/libcomps/src/python/src/pycomps_dict.c
1dfe7b
index 1b42909..4a20cf7 100644
1dfe7b
--- a/libcomps/src/python/src/pycomps_dict.c
1dfe7b
+++ b/libcomps/src/python/src/pycomps_dict.c
1dfe7b
@@ -78,7 +78,7 @@ PyObject* PyCOMPSDict_str(PyObject *self) {
1dfe7b
     pairlist = comps_objdict_pairs(((PyCOMPS_Dict*)self)->dict);
1dfe7b
     char *tmpstr;
1dfe7b
 
1dfe7b
-    for (it = pairlist->first; it != pairlist->last; it = it->next) {
1dfe7b
+    for (it = pairlist->first; it != NULL; it = it->next) {
1dfe7b
         tmp = ret;
1dfe7b
         tmpkey = __pycomps_lang_decode(((COMPS_ObjRTreePair*)it->data)->key);
1dfe7b
         if (!tmpkey) {
1dfe7b
@@ -99,24 +99,6 @@ PyObject* PyCOMPSDict_str(PyObject *self) {
1dfe7b
         Py_XDECREF(tmpkey);
1dfe7b
         Py_XDECREF(tmpval);
1dfe7b
     }
1dfe7b
-    tmp = ret;
1dfe7b
-    tmpkey = __pycomps_lang_decode(((COMPS_RTreePair*)it->data)->key);
1dfe7b
-    if (!tmpkey) {
1dfe7b
-        goto out;
1dfe7b
-    }
1dfe7b
-    tmpstr = comps_object_tostr(((COMPS_ObjRTreePair*)it->data)->data);
1dfe7b
-    tmpval = __pycomps_lang_decode(tmpstr);
1dfe7b
-    free(tmpstr);
1dfe7b
-    if (!tmpval) {
1dfe7b
-        //PyErr_SetString(PyExc_TypeError, "val convert error");
1dfe7b
-        goto out;
1dfe7b
-    }
1dfe7b
-    tmp2 = PyUnicode_FromFormat("%U = '%U'", tmpkey, tmpval);
1dfe7b
-    ret = PyUnicode_Concat(ret, tmp2);
1dfe7b
-    Py_XDECREF(tmp);
1dfe7b
-    Py_XDECREF(tmp2);
1dfe7b
-    Py_XDECREF(tmpkey);
1dfe7b
-    Py_XDECREF(tmpval);
1dfe7b
     
1dfe7b
     tmp = ret;
1dfe7b
     tmp2 = PyUnicode_FromString("}");
1dfe7b
1dfe7b
From 6b4bffb541e70a1715e91ba06de8172b57cd26f0 Mon Sep 17 00:00:00 2001
1dfe7b
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
1dfe7b
Date: Mon, 7 Oct 2019 12:52:59 +0200
1dfe7b
Subject: [PATCH 3/3] Add test for python API with empty *_by_lang dictionary
1dfe7b
 input
1dfe7b
1dfe7b
---
1dfe7b
 .../python/tests/comps/comps_empty_by_lang_tags.xml  | 12 ++++++++++++
1dfe7b
 libcomps/src/python/tests/test_libcomps.py           | 10 ++++++++++
1dfe7b
 2 files changed, 22 insertions(+)
1dfe7b
 create mode 100644 libcomps/src/python/tests/comps/comps_empty_by_lang_tags.xml
1dfe7b
1dfe7b
diff --git a/libcomps/src/python/tests/comps/comps_empty_by_lang_tags.xml b/libcomps/src/python/tests/comps/comps_empty_by_lang_tags.xml
1dfe7b
new file mode 100644
1dfe7b
index 0000000..2f40a86
1dfe7b
--- /dev/null
1dfe7b
+++ b/libcomps/src/python/tests/comps/comps_empty_by_lang_tags.xml
1dfe7b
@@ -0,0 +1,12 @@
1dfe7b
+
1dfe7b
+
1dfe7b
+<comps>
1dfe7b
+  <group>
1dfe7b
+   <id>birds</id>
1dfe7b
+   <description></description>
1dfe7b
+  </group>
1dfe7b
+  <category>
1dfe7b
+   <id>all</id>
1dfe7b
+   <name>all</name>
1dfe7b
+  </category>
1dfe7b
+</comps>
1dfe7b
diff --git a/libcomps/src/python/tests/test_libcomps.py b/libcomps/src/python/tests/test_libcomps.py
1dfe7b
index 71311ef..64c2b59 100755
1dfe7b
--- a/libcomps/src/python/tests/test_libcomps.py
1dfe7b
+++ b/libcomps/src/python/tests/test_libcomps.py
1dfe7b
@@ -153,6 +153,16 @@ def test_duplicate_groups(self):
1dfe7b
         #print self.comps.xml_str()
1dfe7b
         self.comps.fromxml_str(self.comps.xml_str())
1dfe7b
 
1dfe7b
+    def test_empty_by_lang_tags(self):
1dfe7b
+        self.comps = libcomps.Comps()
1dfe7b
+        self.comps.fromxml_f("comps/comps_empty_by_lang_tags.xml")
1dfe7b
+        for group in self.comps.groups:
1dfe7b
+            self.assertEqual("{}", str(group.name_by_lang))
1dfe7b
+            self.assertEqual("{}", str(group.desc_by_lang))
1dfe7b
+
1dfe7b
+        for category in self.comps.categories:
1dfe7b
+            self.assertEqual("{}", str(category.name_by_lang))
1dfe7b
+            self.assertEqual("{}", str(category.desc_by_lang))
1dfe7b
 
1dfe7b
 if __name__ == "__main__":
1dfe7b
     unittest.main(testRunner = utest.MyRunner)