[Spice-devel] [PATCH vd_agent_linux 10/10] Add a test for session_info

Frediano Ziglio fziglio at redhat.com
Tue Nov 3 09:59:03 UTC 2020


Hi,
   this is currently failing on Gitlab CI, I suppose due to the fact
that is run inside a container (potentially not in a user session).

Frediano

> 
> Test from Uri, integrated in test suite.
> 
> Signed-off-by: Uri Lublin <uril at redhat.com>
> Signed-off-by: Frediano Ziglio <freddy77 at gmail.com>
> ---
>  Makefile.am               | 30 ++++++++++++++++++++
>  tests/test-session-info.c | 58 +++++++++++++++++++++++++++++++++++++++
>  2 files changed, 88 insertions(+)
>  create mode 100644 tests/test-session-info.c
> 
> diff --git a/Makefile.am b/Makefile.am
> index 575ba52..f4c65b4 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -109,13 +109,43 @@ src_spice_vdagentd_SOURCES =			\
>  	src/vdagentd/virtio-port.h		\
>  	$(NULL)
>  
> +tests_test_session_info_CFLAGS =		\
> +	$(DBUS_CFLAGS)				\
> +	$(LIBSYSTEMD_DAEMON_CFLAGS)		\
> +	$(LIBSYSTEMD_LOGIN_CFLAGS)		\
> +	$(SPICE_CFLAGS)				\
> +	$(GIO2_CFLAGS)				\
> +	-I$(srcdir)/src				\
> +	-I$(srcdir)/src/vdagentd		\
> +	-DUDSCS_NO_SERVER			\
> +	$(NULL)
> +
> +tests_test_session_info_LDADD =			\
> +	$(DBUS_LIBS)				\
> +	$(LIBSYSTEMD_DAEMON_LIBS)		\
> +	$(LIBSYSTEMD_LOGIN_LIBS)		\
> +	$(SPICE_LIBS)				\
> +	$(GIO2_LIBS)				\
> +	$(NULL)
> +
> +tests_test_session_info_SOURCES =		\
> +	$(common_sources)			\
> +	src/vdagentd/session-info.h		\
> +	tests/test-session-info.c		\
> +	$(NULL)
> +
> +check_PROGRAMS += tests/test-session-info
> +
>  if HAVE_CONSOLE_KIT
>  src_spice_vdagentd_SOURCES += src/vdagentd/console-kit.c
> +tests_test_session_info_SOURCES += src/vdagentd/console-kit.c
>  else
>  if HAVE_LIBSYSTEMD_LOGIN
>  src_spice_vdagentd_SOURCES += src/vdagentd/systemd-login.c
> +tests_test_session_info_SOURCES += src/vdagentd/systemd-login.c
>  else
>  src_spice_vdagentd_SOURCES += src/vdagentd/dummy-session-info.c
> +tests_test_session_info_SOURCES += src/vdagentd/dummy-session-info.c
>  endif
>  endif
>  
> diff --git a/tests/test-session-info.c b/tests/test-session-info.c
> new file mode 100644
> index 0000000..dae3ec6
> --- /dev/null
> +++ b/tests/test-session-info.c
> @@ -0,0 +1,58 @@
> +/*  test-session-info.c  - test session info
> +
> +    Copyright 2020 Red Hat, Inc.
> +
> +    This program is free software: you can redistribute it and/or modify
> +    it under the terms of the GNU General Public License as published by
> +    the Free Software Foundation, either version 3 of the License, or
> +    (at your option) any later version.
> +
> +    This program is distributed in the hope that it will be useful,
> +    but WITHOUT ANY WARRANTY; without even the implied warranty of
> +    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> +    GNU General Public License for more details.
> +
> +    You should have received a copy of the GNU General Public License
> +    along with this program.  If not, see <http://www.gnu.org/licenses/>.
> +*/
> +#include <config.h>
> +
> +#undef NDEBUG
> +#include <assert.h>
> +#include <stdio.h>
> +#include <stdlib.h>
> +#include <unistd.h>
> +
> +#include "session-info.h"
> +
> +int main(int argc, char *argv[])
> +{
> +    int pid, uid, ck_uid;
> +
> +    pid = (int)getpid();
> +
> +    struct session_info *session_info = session_info_create(1);
> +    if (session_info == NULL) {
> +        return 1;
> +    }
> +
> +    char *session = session_info_session_for_pid(session_info, pid);
> +    if (session == NULL) {
> +        session_info_destroy(session_info);
> +        return 2;
> +    }
> +    ck_uid = session_info_uid_for_session(session_info, session);
> +
> +    free(session);
> +    session_info_destroy(session_info);
> +
> +    uid = getuid();
> +    printf("MAIN: uid is %d, ck_uid is %d\n", uid, ck_uid);
> +
> +    if (uid != ck_uid) {
> +        fprintf(stderr, "MAIN: uid (%d) does not match console-kit uid
> %d\n", uid, ck_uid);
> +        return 3;
> +    }
> +
> +    return 0;
> +}



More information about the Spice-devel mailing list