1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-03 05:18:29 +03:00

tests: check for supported dBus interface

Instead of blindly relying on sleeping, that dBus understands our
dBus interface, query the info with dbus-send.
This commit is contained in:
Zdenek Kabelac 2024-04-08 19:48:50 +02:00
parent f524dd80f4
commit 08888d57cb

View File

@ -322,12 +322,23 @@ prepare_lvmdbusd() {
"$daemon" $lvmdbusdebug > debug.log_LVMDBUSD_out 2>&1 & "$daemon" $lvmdbusdebug > debug.log_LVMDBUSD_out 2>&1 &
local pid=$! local pid=$!
sleep 1
echo -n "## checking lvmdbusd IS running..." echo -n "## checking lvmdbusd IS running..."
for i in {50..0}; do
dbus-send --system --dest=org.freedesktop.DBus --type=method_call --print-reply /org/freedesktop/DBus org.freedesktop.DBus.ListNames > dbus_services
grep -q com.redhat.lvmdbus1 dbus_services && break
sleep .1
done
if [ "$i" -eq 0 ] ; then
printf "\nFailed to serve lvm dBus service in 5 seconds.\n"
sed -e "s,^,## DBUS_SERVICES: ," dbus_services
return 1
fi
comm= comm=
# TODO: Is there a better check than wait 1 second and check pid? # TODO: Is there a better check than wait 1 second and check pid?
if ! comm=$(ps -p $pid -o comm=) >/dev/null || [[ $comm != lvmdbusd ]]; then if ! comm=$(ps -p $pid -o comm=) >/dev/null || [[ $comm != lvmdbusd ]]; then
echo "Failed to start lvmdbusd daemon" printf "\nFailed to start lvmdbusd daemon\n"
return 1 return 1
fi fi
echo "$pid" > LOCAL_LVMDBUSD echo "$pid" > LOCAL_LVMDBUSD