2013-07-18 10:54:21 +01:00
/*
2014-03-17 10:38:38 +01:00
* Copyright ( C ) 2013 , 2014 Red Hat , Inc .
2013-07-18 10:54:21 +01:00
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library 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
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library . If not , see
* < http : //www.gnu.org/licenses/>.
*
* Author : Daniel P . Berrange < berrange @ redhat . com >
*/
# include <config.h>
# include "testutils.h"
2014-05-20 15:04:44 -06:00
# if defined(WITH_DBUS) && defined(__linux__)
2013-09-17 11:11:25 -06:00
# include <stdlib.h>
2014-03-12 12:20:07 +00:00
# include <dbus / dbus.h>
2013-09-17 11:11:25 -06:00
2016-06-24 17:41:09 +02:00
# define __VIR_SYSTEMD_PRIV_H_ALLOW__ 1
# include "virsystemdpriv.h"
2013-09-17 11:11:25 -06:00
# include "virsystemd.h"
2016-02-11 11:14:11 +01:00
# include "virdbus.h"
2013-09-17 11:11:25 -06:00
# include "virlog.h"
2014-03-12 12:20:07 +00:00
# include "virmock.h"
2013-09-17 11:11:25 -06:00
# define VIR_FROM_THIS VIR_FROM_NONE
2013-07-18 10:54:21 +01:00
2014-02-28 12:16:17 +00:00
VIR_LOG_INIT ( " tests.systemdtest " ) ;
2014-06-03 12:02:52 +01:00
VIR_MOCK_WRAP_RET_ARGS ( dbus_connection_send_with_reply_and_block ,
2014-03-12 12:20:07 +00:00
DBusMessage * ,
DBusConnection * , connection ,
DBusMessage * , message ,
int , timeout_milliseconds ,
DBusError * , error )
{
DBusMessage * reply = NULL ;
const char * service = dbus_message_get_destination ( message ) ;
const char * member = dbus_message_get_member ( message ) ;
2014-06-03 12:02:52 +01:00
VIR_MOCK_REAL_INIT ( dbus_connection_send_with_reply_and_block ) ;
2014-03-12 12:20:07 +00:00
if ( STREQ ( service , " org.freedesktop.machine1 " ) ) {
if ( getenv ( " FAIL_BAD_SERVICE " ) ) {
dbus_set_error_const ( error ,
" org.freedesktop.systemd.badthing " ,
" Something went wrong creating the machine " ) ;
} else {
reply = dbus_message_new ( DBUS_MESSAGE_TYPE_METHOD_RETURN ) ;
2016-02-02 19:45:55 +01:00
if ( STREQ ( member , " GetMachineByPID " ) ) {
const char * object_path = " /org/freedesktop/machine1/machine/qemu_2ddemo " ;
DBusMessageIter iter ;
dbus_message_iter_init_append ( reply , & iter ) ;
if ( ! dbus_message_iter_append_basic ( & iter ,
DBUS_TYPE_OBJECT_PATH ,
& object_path ) )
goto error ;
} else if ( STREQ ( member , " Get " ) ) {
const char * name = " qemu-demo " ;
DBusMessageIter iter ;
DBusMessageIter sub ;
dbus_message_iter_init_append ( reply , & iter ) ;
dbus_message_iter_open_container ( & iter , DBUS_TYPE_VARIANT ,
" s " , & sub ) ;
if ( ! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& name ) )
goto error ;
dbus_message_iter_close_container ( & iter , & sub ) ;
}
2014-03-12 12:20:07 +00:00
}
2014-04-11 09:20:48 +02:00
} else if ( STREQ ( service , " org.freedesktop.login1 " ) ) {
char * supported = getenv ( " RESULT_SUPPORT " ) ;
DBusMessageIter iter ;
reply = dbus_message_new ( DBUS_MESSAGE_TYPE_METHOD_RETURN ) ;
dbus_message_iter_init_append ( reply , & iter ) ;
if ( ! dbus_message_iter_append_basic ( & iter ,
DBUS_TYPE_STRING ,
& supported ) )
goto error ;
2014-03-12 12:20:07 +00:00
} else if ( STREQ ( service , " org.freedesktop.DBus " ) & &
STREQ ( member , " ListActivatableNames " ) ) {
const char * svc1 = " org.foo.bar.wizz " ;
const char * svc2 = " org.freedesktop.machine1 " ;
2014-04-11 09:20:48 +02:00
const char * svc3 = " org.freedesktop.login1 " ;
2014-03-12 12:20:07 +00:00
DBusMessageIter iter ;
DBusMessageIter sub ;
reply = dbus_message_new ( DBUS_MESSAGE_TYPE_METHOD_RETURN ) ;
dbus_message_iter_init_append ( reply , & iter ) ;
dbus_message_iter_open_container ( & iter , DBUS_TYPE_ARRAY ,
" s " , & sub ) ;
if ( ! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& svc1 ) )
goto error ;
if ( ! getenv ( " FAIL_NO_SERVICE " ) & &
! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& svc2 ) )
goto error ;
2014-04-11 09:20:48 +02:00
if ( ! getenv ( " FAIL_NO_SERVICE " ) & &
! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& svc3 ) )
goto error ;
2014-03-12 12:20:07 +00:00
dbus_message_iter_close_container ( & iter , & sub ) ;
} else if ( STREQ ( service , " org.freedesktop.DBus " ) & &
STREQ ( member , " ListNames " ) ) {
const char * svc1 = " org.foo.bar.wizz " ;
const char * svc2 = " org.freedesktop.systemd1 " ;
2014-04-11 09:20:48 +02:00
const char * svc3 = " org.freedesktop.login1 " ;
2014-03-12 12:20:07 +00:00
DBusMessageIter iter ;
DBusMessageIter sub ;
reply = dbus_message_new ( DBUS_MESSAGE_TYPE_METHOD_RETURN ) ;
dbus_message_iter_init_append ( reply , & iter ) ;
dbus_message_iter_open_container ( & iter , DBUS_TYPE_ARRAY ,
" s " , & sub ) ;
if ( ! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& svc1 ) )
goto error ;
if ( ( ! getenv ( " FAIL_NO_SERVICE " ) & & ! getenv ( " FAIL_NOT_REGISTERED " ) ) & &
! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& svc2 ) )
goto error ;
2014-04-11 09:20:48 +02:00
if ( ( ! getenv ( " FAIL_NO_SERVICE " ) & & ! getenv ( " FAIL_NOT_REGISTERED " ) ) & &
! dbus_message_iter_append_basic ( & sub ,
DBUS_TYPE_STRING ,
& svc3 ) )
goto error ;
2014-03-12 12:20:07 +00:00
dbus_message_iter_close_container ( & iter , & sub ) ;
} else {
reply = dbus_message_new ( DBUS_MESSAGE_TYPE_METHOD_RETURN ) ;
}
return reply ;
error :
2016-02-11 11:14:11 +01:00
virDBusMessageUnref ( reply ) ;
2014-03-12 12:20:07 +00:00
return NULL ;
}
2013-07-18 10:54:21 +01:00
static int testCreateContainer ( const void * opaque ATTRIBUTE_UNUSED )
{
unsigned char uuid [ VIR_UUID_BUFLEN ] = {
1 , 1 , 1 , 1 ,
2 , 2 , 2 , 2 ,
3 , 3 , 3 , 3 ,
4 , 4 , 4 , 4
} ;
if ( virSystemdCreateMachine ( " demo " ,
" lxc " ,
uuid ,
" /proc/123/root " ,
123 ,
true ,
2014-11-11 17:38:43 +00:00
0 , NULL ,
2013-07-18 10:54:21 +01:00
" highpriority.slice " ) < 0 ) {
fprintf ( stderr , " %s " , " Failed to create LXC machine \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-09-30 16:46:29 +02:00
static int testTerminateContainer ( const void * opaque ATTRIBUTE_UNUSED )
{
2016-02-01 16:50:54 +01:00
if ( virSystemdTerminateMachine ( " lxc-demo " ) < 0 ) {
2013-09-30 16:46:29 +02:00
fprintf ( stderr , " %s " , " Failed to terminate LXC machine \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-07-18 10:54:21 +01:00
static int testCreateMachine ( const void * opaque ATTRIBUTE_UNUSED )
{
unsigned char uuid [ VIR_UUID_BUFLEN ] = {
1 , 1 , 1 , 1 ,
2 , 2 , 2 , 2 ,
3 , 3 , 3 , 3 ,
4 , 4 , 4 , 4
} ;
if ( virSystemdCreateMachine ( " demo " ,
" qemu " ,
uuid ,
NULL ,
123 ,
false ,
2014-11-11 17:38:43 +00:00
0 , NULL ,
2013-07-18 10:54:21 +01:00
NULL ) < 0 ) {
fprintf ( stderr , " %s " , " Failed to create KVM machine \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-09-30 16:46:29 +02:00
static int testTerminateMachine ( const void * opaque ATTRIBUTE_UNUSED )
{
2016-02-01 16:50:54 +01:00
if ( virSystemdTerminateMachine ( " test-qemu-demo " ) < 0 ) {
2013-09-30 16:46:29 +02:00
fprintf ( stderr , " %s " , " Failed to terminate KVM machine \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-07-18 10:54:21 +01:00
static int testCreateNoSystemd ( const void * opaque ATTRIBUTE_UNUSED )
{
unsigned char uuid [ VIR_UUID_BUFLEN ] = {
1 , 1 , 1 , 1 ,
2 , 2 , 2 , 2 ,
3 , 3 , 3 , 3 ,
4 , 4 , 4 , 4
} ;
2013-07-22 16:33:37 +01:00
int rv ;
2013-07-18 10:54:21 +01:00
setenv ( " FAIL_NO_SERVICE " , " 1 " , 1 ) ;
2013-07-22 16:33:37 +01:00
if ( ( rv = virSystemdCreateMachine ( " demo " ,
" qemu " ,
uuid ,
NULL ,
123 ,
false ,
2014-11-11 17:38:43 +00:00
0 , NULL ,
2013-07-22 16:33:37 +01:00
NULL ) ) = = 0 ) {
2013-09-11 15:29:52 +01:00
unsetenv ( " FAIL_NO_SERVICE " ) ;
2013-07-18 10:54:21 +01:00
fprintf ( stderr , " %s " , " Unexpected create machine success \n " ) ;
return - 1 ;
}
2013-09-11 15:29:52 +01:00
unsetenv ( " FAIL_NO_SERVICE " ) ;
2013-07-18 10:54:21 +01:00
2013-07-22 16:33:37 +01:00
if ( rv ! = - 2 ) {
fprintf ( stderr , " %s " , " Unexpected create machine error \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-07-18 10:54:21 +01:00
2014-02-27 21:21:57 +01:00
static int testCreateSystemdNotRunning ( const void * opaque ATTRIBUTE_UNUSED )
{
unsigned char uuid [ VIR_UUID_BUFLEN ] = {
1 , 1 , 1 , 1 ,
2 , 2 , 2 , 2 ,
3 , 3 , 3 , 3 ,
4 , 4 , 4 , 4
} ;
int rv ;
setenv ( " FAIL_NOT_REGISTERED " , " 1 " , 1 ) ;
if ( ( rv = virSystemdCreateMachine ( " demo " ,
" qemu " ,
uuid ,
NULL ,
123 ,
false ,
2014-11-11 17:38:43 +00:00
0 , NULL ,
2014-02-27 21:21:57 +01:00
NULL ) ) = = 0 ) {
unsetenv ( " FAIL_NOT_REGISTERED " ) ;
fprintf ( stderr , " %s " , " Unexpected create machine success \n " ) ;
return - 1 ;
}
unsetenv ( " FAIL_NOT_REGISTERED " ) ;
if ( rv ! = - 2 ) {
fprintf ( stderr , " %s " , " Unexpected create machine error \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-07-22 16:33:37 +01:00
static int testCreateBadSystemd ( const void * opaque ATTRIBUTE_UNUSED )
{
unsigned char uuid [ VIR_UUID_BUFLEN ] = {
1 , 1 , 1 , 1 ,
2 , 2 , 2 , 2 ,
3 , 3 , 3 , 3 ,
4 , 4 , 4 , 4
} ;
int rv ;
setenv ( " FAIL_BAD_SERVICE " , " 1 " , 1 ) ;
if ( ( rv = virSystemdCreateMachine ( " demo " ,
" qemu " ,
uuid ,
NULL ,
123 ,
false ,
2014-11-11 17:38:43 +00:00
0 , NULL ,
2013-07-22 16:33:37 +01:00
NULL ) ) = = 0 ) {
2013-09-11 15:29:52 +01:00
unsetenv ( " FAIL_BAD_SERVICE " ) ;
2013-07-22 16:33:37 +01:00
fprintf ( stderr , " %s " , " Unexpected create machine success \n " ) ;
2013-07-18 10:54:21 +01:00
return - 1 ;
}
2013-09-11 15:29:52 +01:00
unsetenv ( " FAIL_BAD_SERVICE " ) ;
2013-07-18 10:54:21 +01:00
2013-07-22 16:33:37 +01:00
if ( rv ! = - 1 ) {
fprintf ( stderr , " %s " , " Unexpected create machine error \n " ) ;
return - 1 ;
}
2013-07-18 10:54:21 +01:00
2013-07-22 16:33:37 +01:00
return 0 ;
2013-07-18 10:54:21 +01:00
}
2013-07-26 15:18:55 +01:00
2014-11-11 17:38:43 +00:00
static int testCreateNetwork ( const void * opaque ATTRIBUTE_UNUSED )
{
unsigned char uuid [ VIR_UUID_BUFLEN ] = {
1 , 1 , 1 , 1 ,
2 , 2 , 2 , 2 ,
3 , 3 , 3 , 3 ,
4 , 4 , 4 , 4
} ;
int nicindexes [ ] = {
2 , 1729 , 87539319 ,
} ;
size_t nnicindexes = ARRAY_CARDINALITY ( nicindexes ) ;
if ( virSystemdCreateMachine ( " demo " ,
" lxc " ,
uuid ,
" /proc/123/root " ,
123 ,
true ,
nnicindexes , nicindexes ,
" highpriority.slice " ) < 0 ) {
fprintf ( stderr , " %s " , " Failed to create LXC machine \n " ) ;
return - 1 ;
}
return 0 ;
}
2016-02-02 19:45:55 +01:00
static int
testGetMachineName ( const void * opaque ATTRIBUTE_UNUSED )
{
char * tmp = virSystemdGetMachineNameByPID ( 1234 ) ;
int ret = - 1 ;
if ( ! tmp ) {
fprintf ( stderr , " %s " , " Failed to create LXC machine \n " ) ;
return ret ;
}
if ( STREQ ( tmp , " qemu-demo " ) )
ret = 0 ;
VIR_FREE ( tmp ) ;
return ret ;
}
2015-11-24 15:56:12 +01:00
struct testNameData {
2013-07-26 15:18:55 +01:00
const char * name ;
const char * expected ;
2016-02-01 16:50:54 +01:00
int id ;
bool legacy ;
2013-07-26 15:18:55 +01:00
} ;
static int
testScopeName ( const void * opaque )
{
2015-11-24 15:56:12 +01:00
const struct testNameData * data = opaque ;
2013-07-26 15:18:55 +01:00
int ret = - 1 ;
char * actual = NULL ;
2016-02-01 16:50:54 +01:00
if ( ! ( actual = virSystemdMakeScopeName ( data - > name , " lxc " , data - > legacy ) ) )
2013-07-26 15:18:55 +01:00
goto cleanup ;
if ( STRNEQ ( actual , data - > expected ) ) {
fprintf ( stderr , " Expected '%s' but got '%s' \n " ,
data - > expected , actual ) ;
goto cleanup ;
}
ret = 0 ;
cleanup :
VIR_FREE ( actual ) ;
return ret ;
}
2015-11-24 15:56:12 +01:00
static int
testMachineName ( const void * opaque )
{
const struct testNameData * data = opaque ;
int ret = - 1 ;
char * actual = NULL ;
2017-07-21 15:51:03 +02:00
if ( ! ( actual = virDomainGenerateMachineName ( " qemu " , data - > id ,
data - > name , true ) ) )
2015-11-24 15:56:12 +01:00
goto cleanup ;
if ( STRNEQ ( actual , data - > expected ) ) {
fprintf ( stderr , " Expected '%s' but got '%s' \n " ,
data - > expected , actual ) ;
goto cleanup ;
}
ret = 0 ;
cleanup :
VIR_FREE ( actual ) ;
return ret ;
}
2014-04-11 09:20:48 +02:00
typedef int ( * virSystemdCanHelper ) ( bool * result ) ;
struct testPMSupportData {
virSystemdCanHelper tested ;
} ;
static int testPMSupportHelper ( const void * opaque )
{
int rv ;
bool result ;
size_t i ;
const char * results [ 4 ] = { " yes " , " no " , " na " , " challenge " } ;
int expected [ 4 ] = { 1 , 0 , 0 , 1 } ;
const struct testPMSupportData * data = opaque ;
for ( i = 0 ; i < 4 ; i + + ) {
setenv ( " RESULT_SUPPORT " , results [ i ] , 1 ) ;
if ( ( rv = data - > tested ( & result ) ) < 0 ) {
fprintf ( stderr , " %s " , " Unexpected canSuspend error \n " ) ;
return - 1 ;
}
if ( result ! = expected [ i ] ) {
fprintf ( stderr , " Unexpected result for answer '%s' \n " , results [ i ] ) ;
goto error ;
}
unsetenv ( " RESULT_SUPPORT " ) ;
}
return 0 ;
error :
unsetenv ( " RESULT_SUPPORT " ) ;
return - 1 ;
}
static int testPMSupportHelperNoSystemd ( const void * opaque )
{
int rv ;
bool result ;
const struct testPMSupportData * data = opaque ;
setenv ( " FAIL_NO_SERVICE " , " 1 " , 1 ) ;
if ( ( rv = data - > tested ( & result ) ) = = 0 ) {
unsetenv ( " FAIL_NO_SERVICE " ) ;
fprintf ( stderr , " %s " , " Unexpected canSuspend success \n " ) ;
return - 1 ;
}
unsetenv ( " FAIL_NO_SERVICE " ) ;
if ( rv ! = - 2 ) {
fprintf ( stderr , " %s " , " Unexpected canSuspend error \n " ) ;
return - 1 ;
}
return 0 ;
}
static int testPMSupportSystemdNotRunning ( const void * opaque )
{
int rv ;
bool result ;
const struct testPMSupportData * data = opaque ;
setenv ( " FAIL_NOT_REGISTERED " , " 1 " , 1 ) ;
if ( ( rv = data - > tested ( & result ) ) = = 0 ) {
unsetenv ( " FAIL_NOT_REGISTERED " ) ;
fprintf ( stderr , " %s " , " Unexpected canSuspend success \n " ) ;
return - 1 ;
}
unsetenv ( " FAIL_NOT_REGISTERED " ) ;
if ( rv ! = - 2 ) {
fprintf ( stderr , " %s " , " Unexpected canSuspend error \n " ) ;
return - 1 ;
}
return 0 ;
}
2013-07-18 10:54:21 +01:00
static int
mymain ( void )
{
int ret = 0 ;
2016-02-01 16:50:54 +01:00
unsigned char uuid [ VIR_UUID_BUFLEN ] ;
/* The one we use in tests quite often */
if ( virUUIDParse ( " c7a5fdbd-edaf-9455-926a-d65c16db1809 " , uuid ) < 0 )
return EXIT_FAILURE ;
2017-11-03 13:09:47 +01:00
# define DO_TEST(_name, func) \
do { \
if ( virTestRun ( _name , func , NULL ) < 0 ) \
ret = - 1 ; \
if ( virTestRun ( _name " again " , func , NULL ) < 0 ) \
ret = - 1 ; \
virSystemdHasMachinedResetCachedValue ( ) ; \
2017-02-23 12:25:33 +01:00
} while ( 0 )
DO_TEST ( " Test create container " , testCreateContainer ) ;
DO_TEST ( " Test terminate container " , testTerminateContainer ) ;
DO_TEST ( " Test create machine " , testCreateMachine ) ;
DO_TEST ( " Test terminate machine " , testTerminateMachine ) ;
DO_TEST ( " Test create no systemd " , testCreateNoSystemd ) ;
DO_TEST ( " Test create systemd not running " , testCreateSystemdNotRunning ) ;
DO_TEST ( " Test create bad systemd " , testCreateBadSystemd ) ;
DO_TEST ( " Test create with network " , testCreateNetwork ) ;
DO_TEST ( " Test getting machine name " , testGetMachineName ) ;
2013-07-18 10:54:21 +01:00
2017-11-03 13:09:47 +01:00
# define TEST_SCOPE(_name, unitname, _legacy) \
do { \
struct testNameData data = { \
. name = _name , . expected = unitname , . legacy = _legacy , \
} ; \
if ( virTestRun ( " Test scopename " , testScopeName , & data ) < 0 ) \
ret = - 1 ; \
2013-07-26 15:18:55 +01:00
} while ( 0 )
2017-11-03 13:09:47 +01:00
# define TEST_SCOPE_OLD(name, unitname) \
2016-02-01 16:50:54 +01:00
TEST_SCOPE ( name , unitname , true )
2017-11-03 13:09:47 +01:00
# define TEST_SCOPE_NEW(name, unitname) \
2016-02-01 16:50:54 +01:00
TEST_SCOPE ( name , unitname , false )
TEST_SCOPE_OLD ( " demo " , " machine-lxc \\ x2ddemo.scope " ) ;
TEST_SCOPE_OLD ( " demo-name " , " machine-lxc \\ x2ddemo \\ x2dname.scope " ) ;
TEST_SCOPE_OLD ( " demo!name " , " machine-lxc \\ x2ddemo \\ x21name.scope " ) ;
TEST_SCOPE_OLD ( " .demo " , " machine-lxc \\ x2d \\ x2edemo.scope " ) ;
TEST_SCOPE_OLD ( " bull💩 " , " machine-lxc \\ x2dbull \\ xf0 \\ x9f \\ x92 \\ xa9.scope " ) ;
TEST_SCOPE_NEW ( " qemu-3-demo " , " machine-qemu \\ x2d3 \\ x2ddemo.scope " ) ;
2015-11-24 15:56:12 +01:00
2017-11-03 13:09:47 +01:00
# define TEST_MACHINE(_name, _id, machinename) \
do { \
struct testNameData data = { \
. name = _name , . expected = machinename , . id = _id , \
} ; \
if ( virTestRun ( " Test scopename " , testMachineName , & data ) < 0 ) \
ret = - 1 ; \
2015-11-24 15:56:12 +01:00
} while ( 0 )
2016-02-01 16:50:54 +01:00
TEST_MACHINE ( " demo " , 1 , " qemu-1-demo " ) ;
TEST_MACHINE ( " demo-name " , 2 , " qemu-2-demo-name " ) ;
TEST_MACHINE ( " demo!name " , 3 , " qemu-3-demoname " ) ;
TEST_MACHINE ( " .demo " , 4 , " qemu-4-.demo " ) ;
TEST_MACHINE ( " bull \U0001f4a9 " , 5 , " qemu-5-bull " ) ;
TEST_MACHINE ( " demo..name " , 6 , " qemu-6-demo.name " ) ;
TEST_MACHINE ( " 12345678901234567890123456789012345678901234567890123456789 " , 7 ,
" qemu-7-123456789012345678901234567890123456789012345678901234567 " ) ;
TEST_MACHINE ( " 123456789012345678901234567890123456789012345678901234567890 " , 8 ,
" qemu-8-123456789012345678901234567890123456789012345678901234567 " ) ;
2013-07-26 15:18:55 +01:00
2017-11-03 13:09:47 +01:00
# define TESTS_PM_SUPPORT_HELPER(name, function) \
do { \
struct testPMSupportData data = { \
function \
} ; \
if ( virTestRun ( " Test " name " " , testPMSupportHelper , & data ) < 0 ) \
ret = - 1 ; \
if ( virTestRun ( " Test " name " no systemd " , \
testPMSupportHelperNoSystemd , & data ) < 0 ) \
ret = - 1 ; \
if ( virTestRun ( " Test systemd " name " not running " , \
testPMSupportSystemdNotRunning , & data ) < 0 ) \
ret = - 1 ; \
2014-04-11 09:20:48 +02:00
} while ( 0 )
TESTS_PM_SUPPORT_HELPER ( " canSuspend " , & virSystemdCanSuspend ) ;
TESTS_PM_SUPPORT_HELPER ( " canHibernate " , & virSystemdCanHibernate ) ;
TESTS_PM_SUPPORT_HELPER ( " canHybridSleep " , & virSystemdCanHybridSleep ) ;
2014-03-17 10:38:38 +01:00
return ret = = 0 ? EXIT_SUCCESS : EXIT_FAILURE ;
2013-07-18 10:54:21 +01:00
}
2017-03-29 16:45:42 +02:00
VIR_TEST_MAIN_PRELOAD ( mymain , abs_builddir " /.libs/virdbusmock.so " )
2013-09-17 11:11:25 -06:00
2014-05-20 15:04:44 -06:00
# else /* ! (WITH_DBUS && __linux__) */
2013-09-17 11:11:25 -06:00
int
main ( void )
{
return EXIT_AM_SKIP ;
}
2014-03-12 12:20:07 +00:00
# endif /* ! WITH_DBUS */