From 5242eef8fc54636a41701fd9d7083ba6e4a4e0b3 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 26 Jun 2024 18:18:39 +0200 Subject: Merging upstream version 1:4.15.2. Signed-off-by: Daniel Baumann --- tests/unit/test_logind.c | 69 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 tests/unit/test_logind.c (limited to 'tests/unit/test_logind.c') diff --git a/tests/unit/test_logind.c b/tests/unit/test_logind.c new file mode 100644 index 0000000..f91782c --- /dev/null +++ b/tests/unit/test_logind.c @@ -0,0 +1,69 @@ +/* + * SPDX-FileCopyrightText: 2023, Iker Pedrosa + * + * SPDX-License-Identifier: BSD-3-Clause + */ + +#include +#include +#include +#include + +#include +#include +#include + +#include "prototypes.h" + +/*********************** + * WRAPPERS + **********************/ +struct passwd * +__wrap_prefix_getpwnam(uid_t uid) +{ + return (struct passwd*) mock(); +} + +int +__wrap_sd_uid_get_sessions(uid_t uid, int require_active, char ***sessions) +{ + return mock(); +} + +/*********************** + * TEST + **********************/ +static void test_active_sessions_count_return_ok(void **state) +{ + int count; + struct passwd *pw = malloc(sizeof(struct passwd)); + + will_return(__wrap_prefix_getpwnam, pw); + will_return(__wrap_sd_uid_get_sessions, 1); + + count = active_sessions_count("testuser", 0); + + assert_int_equal(count, 1); +} + +static void test_active_sessions_count_prefix_getpwnam_failure(void **state) +{ + int count; + struct passwd *pw = NULL; + + will_return(__wrap_prefix_getpwnam, pw); + + count = active_sessions_count("testuser", 0); + + assert_int_equal(count, 0); +} + +int main(void) +{ + const struct CMUnitTest tests[] = { + cmocka_unit_test(test_active_sessions_count_return_ok), + cmocka_unit_test(test_active_sessions_count_prefix_getpwnam_failure), + }; + + return cmocka_run_group_tests(tests, NULL, NULL); +} -- cgit v1.2.3