|
|
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 |
|