2022-06-10 07:55:54 +03:00
#!/usr/bin/env bash
# SPDX-License-Identifier: LGPL-2.1-or-later
set -eux
set -o pipefail
# shellcheck source=test/units/assert.sh
. " $( dirname " $0 " ) " /assert.sh
2022-06-14 03:02:00 +03:00
restore_timezone( ) {
if [ [ -f /tmp/timezone.bak ] ] ; then
mv /tmp/timezone.bak /etc/timezone
else
rm -f /etc/timezone
fi
}
2022-06-10 07:55:54 +03:00
test_timezone( ) {
local ORIG_TZ =
2022-06-14 03:02:00 +03:00
# Debian/Ubuntu specific file
if [ [ -f /etc/timezone ] ] ; then
mv /etc/timezone /tmp/timezone.bak
fi
2022-06-14 15:08:04 +03:00
trap restore_timezone RETURN
2022-06-14 03:02:00 +03:00
2022-06-10 07:55:54 +03:00
if [ [ -L /etc/localtime ] ] ; then
ORIG_TZ = $( readlink /etc/localtime | sed 's#^.*zoneinfo/##' )
echo " original tz: $ORIG_TZ "
fi
echo 'timedatectl works'
assert_in "Local time:" " $( timedatectl --no-pager) "
echo 'change timezone'
assert_eq " $( timedatectl --no-pager set-timezone Europe/Kiev 2>& 1) " ""
assert_eq " $( readlink /etc/localtime | sed 's#^.*zoneinfo/##' ) " "Europe/Kiev"
2022-06-14 03:02:00 +03:00
if [ [ -f /etc/timezone ] ] ; then
assert_eq " $( cat /etc/timezone) " "Europe/Kiev"
fi
2022-10-30 05:59:10 +03:00
assert_in "Time zone: Europe/Kiev \(EES*T, \+0[0-9]00\)" " $( timedatectl) "
2022-06-10 07:55:54 +03:00
if [ [ -n " $ORIG_TZ " ] ] ; then
echo 'reset timezone to original'
2022-06-14 03:01:00 +03:00
assert_eq " $( timedatectl set-timezone " $ORIG_TZ " 2>& 1) " ""
2022-06-10 07:55:54 +03:00
assert_eq " $( readlink /etc/localtime | sed 's#^.*zoneinfo/##' ) " " $ORIG_TZ "
2022-06-14 03:02:00 +03:00
if [ [ -f /etc/timezone ] ] ; then
assert_eq " $( cat /etc/timezone) " " $ORIG_TZ "
fi
2022-06-10 07:55:54 +03:00
fi
}
restore_adjtime( ) {
if [ [ -e /etc/adjtime.bak ] ] ; then
mv /etc/adjtime.bak /etc/adjtime
else
rm /etc/adjtime
fi
}
check_adjtime_not_exist( ) {
if [ [ -e /etc/adjtime ] ] ; then
echo "/etc/adjtime unexpectedly exists." >& 2
exit 1
fi
}
test_adjtime( ) {
# test setting UTC vs. LOCAL in /etc/adjtime
if [ [ -e /etc/adjtime ] ] ; then
mv /etc/adjtime /etc/adjtime.bak
fi
2022-06-14 15:08:04 +03:00
trap restore_adjtime RETURN
2022-06-10 07:55:54 +03:00
echo 'no adjtime file'
rm -f /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
timedatectl set-local-rtc 0
check_adjtime_not_exist
echo 'UTC set in adjtime file'
printf '0.0 0 0\n0\nUTC\n' > /etc/adjtime
timedatectl set-local-rtc 0
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
UTC"
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
echo 'non-zero values in adjtime file'
printf '0.1 123 0\n0\nLOCAL\n' > /etc/adjtime
timedatectl set-local-rtc 0
assert_eq " $( cat /etc/adjtime) " " 0.1 123 0
0
UTC"
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.1 123 0
0
LOCAL"
echo 'fourth line adjtime file'
printf '0.0 0 0\n0\nLOCAL\nsomethingelse\n' > /etc/adjtime
timedatectl set-local-rtc 0
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
UTC
somethingelse"
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL
somethingelse"
echo 'no final newline in adjtime file'
printf '0.0 0 0\n0\nUTC' > /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
printf '0.0 0 0\n0\nUTC' > /etc/adjtime
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
echo 'only one line in adjtime file'
printf '0.0 0 0\n' > /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
printf '0.0 0 0\n' > /etc/adjtime
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
echo 'only one line in adjtime file, no final newline'
printf '0.0 0 0' > /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
printf '0.0 0 0' > /etc/adjtime
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
echo 'only two lines in adjtime file'
printf '0.0 0 0\n0\n' > /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
printf '0.0 0 0\n0\n' > /etc/adjtime
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
echo 'only two lines in adjtime file, no final newline'
printf '0.0 0 0\n0' > /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
printf '0.0 0 0\n0' > /etc/adjtime
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
echo 'unknown value in 3rd line of adjtime file'
printf '0.0 0 0\n0\nFOO\n' > /etc/adjtime
timedatectl set-local-rtc 0
check_adjtime_not_exist
printf '0.0 0 0\n0\nFOO\n' > /etc/adjtime
timedatectl set-local-rtc 1
assert_eq " $( cat /etc/adjtime) " " 0.0 0 0
0
LOCAL"
}
assert_ntp( ) {
assert_eq " $( busctl get-property org.freedesktop.timedate1 /org/freedesktop/timedate1 org.freedesktop.timedate1 NTP) " " b $1 "
}
start_mon( ) {
busctl monitor --match= "type='signal',sender=org.freedesktop.timedate1,member='PropertiesChanged',path=/org/freedesktop/timedate1" >" $mon " &
MONPID = $!
}
wait_mon( ) {
2022-06-14 15:05:10 +03:00
for ( ( i = 0; i < 10; i++) ) ; do
2022-06-10 07:55:54 +03:00
if ( ( i != 0 ) ) ; then sleep 1; fi
if grep -q " $1 " " $mon " ; then break; fi
done
assert_in " $2 " " $( cat " $mon " ) "
kill " $MONPID "
wait " $MONPID " 2>/dev/null || true
}
test_ntp( ) {
# timesyncd has ConditionVirtualization=!container by default; drop/mock that for testing
if systemd-detect-virt --container --quiet; then
systemctl disable --quiet --now systemd-timesyncd
mkdir -p /run/systemd/system/systemd-timesyncd.service.d
cat >/run/systemd/system/systemd-timesyncd.service.d/container.conf <<EOF
[ Unit]
ConditionVirtualization =
[ Service]
Type = simple
AmbientCapabilities =
ExecStart =
ExecStart = /bin/sleep infinity
EOF
systemctl daemon-reload
fi
mon = $( mktemp -t dbusmon.XXXXXX)
echo 'disable NTP'
timedatectl set-ntp false
2022-06-14 15:05:10 +03:00
for ( ( i = 0; i < 10; i++) ) ; do
2022-06-10 07:55:54 +03:00
if ( ( i != 0 ) ) ; then sleep 1; fi
2022-06-14 03:01:00 +03:00
if [ [ " $( systemctl show systemd-timesyncd --property ActiveState) " = = "ActiveState=inactive" ] ] ; then
2022-06-10 07:55:54 +03:00
break;
fi
done
2022-06-14 03:01:00 +03:00
assert_eq " $( systemctl show systemd-timesyncd --property ActiveState) " "ActiveState=inactive"
2022-06-10 07:55:54 +03:00
assert_ntp "false"
assert_rc 3 systemctl is-active --quiet systemd-timesyncd
echo 'enable NTP'
start_mon
timedatectl set-ntp true
wait_mon "NTP" "BOOLEAN true"
assert_ntp "true"
2022-06-14 15:05:10 +03:00
for ( ( i = 0; i < 10; i++) ) ; do
2022-06-10 07:55:54 +03:00
if ( ( i != 0 ) ) ; then sleep 1; fi
2022-06-14 03:01:00 +03:00
if [ [ " $( systemctl show systemd-timesyncd --property ActiveState) " = = "ActiveState=active" ] ] ; then
2022-06-10 07:55:54 +03:00
break;
fi
done
2022-06-14 03:01:00 +03:00
assert_eq " $( systemctl show systemd-timesyncd --property ActiveState) " "ActiveState=active"
2022-06-10 07:55:54 +03:00
assert_rc 0 systemctl is-active --quiet systemd-timesyncd
echo 're-disable NTP'
start_mon
timedatectl set-ntp false
wait_mon "NTP" "BOOLEAN false"
assert_ntp "false"
assert_rc 3 systemctl is-active --quiet systemd-timesyncd
}
: >/failed
test_timezone
test_adjtime
test_ntp
touch /testok
rm /failed