1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-02-03 13:47:04 +03:00

Merge pull request #5999 from mbiebl/timesyncd-fallback-server

timesyncd: don't use compiled-in list if FallbackNTP has been configured
This commit is contained in:
Zbigniew Jędrzejewski-Szmek 2017-05-25 18:51:08 -04:00 committed by GitHub
commit 2340bfbfcc
9 changed files with 102 additions and 4 deletions

1
.gitignore vendored
View File

@ -293,6 +293,7 @@
/test-tables
/test-terminal-util
/test-time
/test-timesync
/test-tmpfiles
/test-udev
/test-uid-range

View File

@ -5223,6 +5223,25 @@ systemd_timesyncd_LDADD = \
libsystemd-shared.la \
-lm
test_timesync_SOURCES = \
src/timesync/test-timesync.c \
src/timesync/timesyncd-manager.c \
src/timesync/timesyncd-manager.h \
src/timesync/timesyncd-conf.c \
src/timesync/timesyncd-conf.h \
src/timesync/timesyncd-server.c \
src/timesync/timesyncd-server.h
nodist_test_timesync_SOURCES = \
src/timesync/timesyncd-gperf.c
test_timesync_LDADD = \
libsystemd-shared.la \
-lm
tests += \
test-timesync
rootlibexec_PROGRAMS += \
systemd-timesyncd

View File

@ -24,3 +24,19 @@ if conf.get('ENABLE_TIMESYNCD', false)
install_data(timesyncd_conf,
install_dir : pkgsysconfdir)
endif
############################################################
tests += [
[['src/timesync/test-timesync.c',
'src/timesync/timesyncd-manager.c',
'src/timesync/timesyncd-manager.h',
'src/timesync/timesyncd-conf.c',
'src/timesync/timesyncd-conf.h',
'src/timesync/timesyncd-server.c',
'src/timesync/timesyncd-server.h',
timesyncd_gperf_c],
[libshared],
[libm],
'ENABLE_TIMESYNCD'],
]

View File

@ -0,0 +1,51 @@
/***
This file is part of systemd.
Copyright 2017 Zbigniew Jędrzejewski-Szmek
systemd 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.
systemd 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 systemd; If not, see <http://www.gnu.org/licenses/>.
***/
/* Some unit tests for the helper functions in timesyncd. */
#include "log.h"
#include "macro.h"
#include "timesyncd-conf.h"
static void test_manager_parse_string(void) {
/* Make sure that NTP_SERVERS is configured to something
* that we can actually parse successfully. */
_cleanup_(manager_freep) Manager *m = NULL;
assert_se(manager_new(&m) == 0);
assert_se(!m->have_fallbacks);
assert_se(manager_parse_server_string(m, SERVER_FALLBACK, NTP_SERVERS) == 0);
assert_se(m->have_fallbacks);
assert_se(manager_parse_fallback_string(m, NTP_SERVERS) == 0);
assert_se(manager_parse_server_string(m, SERVER_SYSTEM, "time1.foobar.com time2.foobar.com") == 0);
assert_se(manager_parse_server_string(m, SERVER_FALLBACK, "time1.foobar.com time2.foobar.com") == 0);
assert_se(manager_parse_server_string(m, SERVER_LINK, "time1.foobar.com time2.foobar.com") == 0);
}
int main(int argc, char **argv) {
log_set_max_level(LOG_DEBUG);
log_parse_environment();
test_manager_parse_string();
return 0;
}

View File

@ -34,6 +34,9 @@ int manager_parse_server_string(Manager *m, ServerType type, const char *string)
first = type == SERVER_FALLBACK ? m->fallback_servers : m->system_servers;
if (type == SERVER_FALLBACK)
m->have_fallbacks = true;
for (;;) {
_cleanup_free_ char *word = NULL;
bool found = false;
@ -63,6 +66,13 @@ int manager_parse_server_string(Manager *m, ServerType type, const char *string)
return 0;
}
int manager_parse_fallback_string(Manager *m, const char *string) {
if (m->have_fallbacks)
return 0;
return manager_parse_server_string(m, SERVER_FALLBACK, string);
}
int config_parse_servers(
const char *unit,
const char *filename,

View File

@ -29,3 +29,4 @@ int manager_parse_server_string(Manager *m, ServerType type, const char *string)
int config_parse_servers(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);
int manager_parse_config_file(Manager *m);
int manager_parse_fallback_string(Manager *m, const char *string);

View File

@ -1124,10 +1124,6 @@ int manager_new(Manager **ret) {
RATELIMIT_INIT(m->ratelimit, RATELIMIT_INTERVAL_USEC, RATELIMIT_BURST);
r = manager_parse_server_string(m, SERVER_FALLBACK, NTP_SERVERS);
if (r < 0)
return r;
r = sd_event_default(&m->event);
if (r < 0)
return r;

View File

@ -38,6 +38,8 @@ struct Manager {
LIST_HEAD(ServerName, link_servers);
LIST_HEAD(ServerName, fallback_servers);
bool have_fallbacks:1;
RateLimit ratelimit;
bool exhausted_servers;

View File

@ -132,6 +132,8 @@ int main(int argc, char *argv[]) {
if (r < 0)
log_warning_errno(r, "Failed to parse configuration file: %m");
assert_se(manager_parse_fallback_string(m, NTP_SERVERS) >= 0);
log_debug("systemd-timesyncd running as pid " PID_FMT, getpid());
sd_notify(false,
"READY=1\n"