Blame SOURCES/0118-TESTS-Order-list-of-entries-in-some-lists.patch

96eb28
From 1a73dbe9747aec2818fabd179e0fb46695d66433 Mon Sep 17 00:00:00 2001
96eb28
From: =?UTF-8?q?Michal=20=C5=BDidek?= <mzidek@redhat.com>
96eb28
Date: Mon, 13 Nov 2017 16:15:21 +0100
96eb28
Subject: [PATCH] TESTS: Order list of entries in some lists
96eb28
MIME-Version: 1.0
96eb28
Content-Type: text/plain; charset=UTF-8
96eb28
Content-Transfer-Encoding: 8bit
96eb28
96eb28
Some tests started to fail because we depended on specific
96eb28
order of users in groups or messages in ldb results to be
96eb28
returned and that order changed.
96eb28
96eb28
This patch adds a simple helper functions into these tests
96eb28
that order the entries before comparison with expected results.
96eb28
more deterministic.
96eb28
96eb28
Resolves:
96eb28
https://pagure.io/SSSD/sssd/issue/3563
96eb28
96eb28
Reviewed-by: Lukáš Slebodník <lslebodn@redhat.com>
96eb28
(cherry picked from commit caae0e53e6091806634943699f4398b6a20273b4)
96eb28
96eb28
DOWNSTREAM:
96eb28
Resolves: rhbz#1596292 - home dir disappear in sssd cache on the IPA master for AD users [rhel-7.5.z]
96eb28
---
96eb28
 src/tests/cmocka/test_nss_srv.c     | 22 +++++++++++++++++++
96eb28
 src/tests/cmocka/test_sysdb_views.c | 42 ++++++++++++++++++++++++++++++++-----
96eb28
 2 files changed, 59 insertions(+), 5 deletions(-)
96eb28
96eb28
diff --git a/src/tests/cmocka/test_nss_srv.c b/src/tests/cmocka/test_nss_srv.c
96eb28
index 6aa726153183b5a871a75d398727ea7132358ca6..21bd80fb7f6562f6a31452bac6a26c109fef4cb1 100644
96eb28
--- a/src/tests/cmocka/test_nss_srv.c
96eb28
+++ b/src/tests/cmocka/test_nss_srv.c
96eb28
@@ -585,6 +585,25 @@ static errno_t delete_group(struct nss_test_ctx *ctx,
96eb28
     return ret;
96eb28
 }
96eb28
 
96eb28
+static int cmp_func(const void *a, const void *b)
96eb28
+{
96eb28
+    char *str1 = *(char **)discard_const(a);
96eb28
+    char *str2 = *(char **)discard_const(b);
96eb28
+
96eb28
+    return strcmp(str1, str2);
96eb28
+}
96eb28
+
96eb28
+static void order_string_array(char **_list, int size)
96eb28
+{
96eb28
+    if (size < 2 || _list == NULL || *_list == NULL) {
96eb28
+        /* Nothing to do */
96eb28
+        return;
96eb28
+    }
96eb28
+
96eb28
+    qsort(_list, size, sizeof(char *), cmp_func);
96eb28
+    return;
96eb28
+}
96eb28
+
96eb28
 static void assert_groups_equal(struct group *expected,
96eb28
                                 struct group *gr, const int nmem)
96eb28
 {
96eb28
@@ -594,6 +613,9 @@ static void assert_groups_equal(struct group *expected,
96eb28
     assert_string_equal(gr->gr_name, expected->gr_name);
96eb28
     assert_string_equal(gr->gr_passwd, expected->gr_passwd);
96eb28
 
96eb28
+    order_string_array(gr->gr_mem, nmem);
96eb28
+    order_string_array(expected->gr_mem, nmem);
96eb28
+
96eb28
     for (i = 0; i < nmem; i++) {
96eb28
         assert_string_equal(gr->gr_mem[i], expected->gr_mem[i]);
96eb28
     }
96eb28
diff --git a/src/tests/cmocka/test_sysdb_views.c b/src/tests/cmocka/test_sysdb_views.c
96eb28
index 0378254b4440b29c3182faf2adde8c3db8a4ce97..dd3eb50f9310ff925734dcf51a669d08a638aefd 100644
96eb28
--- a/src/tests/cmocka/test_sysdb_views.c
96eb28
+++ b/src/tests/cmocka/test_sysdb_views.c
96eb28
@@ -22,6 +22,7 @@
96eb28
     along with this program.  If not, see <http://www.gnu.org/licenses/>.
96eb28
 */
96eb28
 
96eb28
+#include <stdlib.h>
96eb28
 #include <stdarg.h>
96eb28
 #include <stddef.h>
96eb28
 #include <setjmp.h>
96eb28
@@ -612,6 +613,31 @@ static int test_enum_users_setup(void **state)
96eb28
     return 0;
96eb28
 }
96eb28
 
96eb28
+static int cmp_func(const void *a, const void *b)
96eb28
+{
96eb28
+    const char *str1;
96eb28
+    const char *str2;
96eb28
+    struct ldb_message *msg1 = *(struct ldb_message **)discard_const(a);
96eb28
+    struct ldb_message *msg2 = *(struct ldb_message **)discard_const(b);
96eb28
+
96eb28
+    str1 = ldb_msg_find_attr_as_string(msg1, SYSDB_NAME, NULL);
96eb28
+    str2 = ldb_msg_find_attr_as_string(msg2, SYSDB_NAME, NULL);
96eb28
+
96eb28
+    return strcmp(str1, str2);
96eb28
+}
96eb28
+
96eb28
+/* Make the order of ldb results deterministic */
96eb28
+static void order_ldb_res_msgs(struct ldb_result *res)
96eb28
+{
96eb28
+    if (res == NULL || res->count < 2) {
96eb28
+        /* Nothing to do */
96eb28
+        return;
96eb28
+    }
96eb28
+
96eb28
+    qsort(res->msgs, res->count, sizeof(struct ldb_message *), cmp_func);
96eb28
+    return;
96eb28
+}
96eb28
+
96eb28
 static void assert_user_attrs(struct ldb_message *msg,
96eb28
                               struct sss_domain_info *dom,
96eb28
                               const char *shortname,
96eb28
@@ -660,8 +686,9 @@ static void check_enumpwent(int ret, struct sss_domain_info *dom,
96eb28
     assert_int_equal(ret, EOK);
96eb28
     assert_int_equal(res->count, N_ELEMENTS(users)-1);
96eb28
 
96eb28
-    assert_user_attrs(res->msgs[0], dom, "barney", views);
96eb28
-    assert_user_attrs(res->msgs[1], dom, "alice", views);
96eb28
+    order_ldb_res_msgs(res);
96eb28
+    assert_user_attrs(res->msgs[0], dom, "alice", views);
96eb28
+    assert_user_attrs(res->msgs[1], dom, "barney", views);
96eb28
     assert_user_attrs(res->msgs[2], dom, "bob", views);
96eb28
 }
96eb28
 
96eb28
@@ -703,6 +730,7 @@ static void test_sysdb_enumpwent_filter(void **state)
96eb28
     ret = sysdb_enumpwent_filter(test_ctx, test_ctx->domain, "b*", 0, &res;;
96eb28
     assert_int_equal(ret, EOK);
96eb28
     assert_int_equal(res->count, 2);
96eb28
+    order_ldb_res_msgs(res);
96eb28
     assert_user_attrs(res->msgs[0], test_ctx->domain, "barney", false);
96eb28
     assert_user_attrs(res->msgs[1], test_ctx->domain, "bob", false);
96eb28
 
96eb28
@@ -749,6 +777,7 @@ static void test_sysdb_enumpwent_filter_views(void **state)
96eb28
                                             "b*", NULL, &res;;
96eb28
     assert_int_equal(ret, EOK);
96eb28
     assert_int_equal(res->count, 2);
96eb28
+    order_ldb_res_msgs(res);
96eb28
     assert_user_attrs(res->msgs[0], test_ctx->domain, "barney", true);
96eb28
     assert_user_attrs(res->msgs[1], test_ctx->domain, "bob", true);
96eb28
 
96eb28
@@ -896,10 +925,11 @@ static void check_enumgrent(int ret, struct sss_domain_info *dom,
96eb28
 {
96eb28
     assert_int_equal(ret, EOK);
96eb28
     assert_int_equal(res->count, N_ELEMENTS(groups)-1);
96eb28
-    assert_group_attrs(res->msgs[0], dom, "three",
96eb28
-                       views ? TEST_GID_OVERRIDE_BASE + 2 : 0);
96eb28
-    assert_group_attrs(res->msgs[1], dom, "one",
96eb28
+    order_ldb_res_msgs(res);
96eb28
+    assert_group_attrs(res->msgs[0], dom, "one",
96eb28
                        views ? TEST_GID_OVERRIDE_BASE : 0);
96eb28
+    assert_group_attrs(res->msgs[1], dom, "three",
96eb28
+                       views ? TEST_GID_OVERRIDE_BASE + 2 : 0);
96eb28
     assert_group_attrs(res->msgs[2], dom, "two",
96eb28
                        views ? TEST_GID_OVERRIDE_BASE + 1 : 0);
96eb28
 }
96eb28
@@ -942,6 +972,7 @@ static void test_sysdb_enumgrent_filter(void **state)
96eb28
     ret = sysdb_enumgrent_filter(test_ctx, test_ctx->domain, "t*", 0, &res;;
96eb28
     assert_int_equal(ret, EOK);
96eb28
     assert_int_equal(res->count, 2);
96eb28
+    order_ldb_res_msgs(res);
96eb28
     assert_group_attrs(res->msgs[0], test_ctx->domain, "three", 0);
96eb28
     assert_group_attrs(res->msgs[1], test_ctx->domain, "two", 0);
96eb28
 
96eb28
@@ -988,6 +1019,7 @@ static void test_sysdb_enumgrent_filter_views(void **state)
96eb28
                                             "t*", NULL, &res;;
96eb28
     assert_int_equal(ret, EOK);
96eb28
     assert_int_equal(res->count, 2);
96eb28
+    order_ldb_res_msgs(res);
96eb28
     assert_group_attrs(res->msgs[0], test_ctx->domain,
96eb28
                        "three", TEST_GID_OVERRIDE_BASE + 2);
96eb28
     assert_group_attrs(res->msgs[1], test_ctx->domain, "two",
96eb28
-- 
96eb28
2.14.4
96eb28