]> ruderich.org/simon Gitweb - safcm/safcm.git/log
safcm/safcm.git
5 days agoRemove permission checks on local files and remove `safcm fixperms`
Simon Ruderich [Sun, 19 Oct 2025 07:19:01 +0000 (09:19 +0200)]
Remove permission checks on local files and remove `safcm fixperms`

The intended use case was to "protect" users against unexpected behavior
when migrating from a legacy system configuration management. This no
longer applies.

In addition, needing to run fixperms is generally annoying and makes the
tests more complex and fragile.

`safcm fixperms` is kept as command not to break existing workflows. It
has no effect now.

6 days agoUse 4 spaces per tab for Go files
Simon Ruderich [Sat, 18 Oct 2025 06:52:51 +0000 (08:52 +0200)]
Use 4 spaces per tab for Go files

6 days agoUpdate dependencies, static checkers and Go to 1.24
Simon Ruderich [Fri, 17 Oct 2025 15:44:33 +0000 (17:44 +0200)]
Update dependencies, static checkers and Go to 1.24

6 months agoconfig: tests: explicitly test permissions without leading zero
Simon Ruderich [Tue, 8 Apr 2025 03:37:37 +0000 (05:37 +0200)]
config: tests: explicitly test permissions without leading zero

6 months agoUpdate copyright years
Simon Ruderich [Tue, 8 Apr 2025 03:37:31 +0000 (05:37 +0200)]
Update copyright years

21 months agoUse SPDX license identifiers
Simon Ruderich [Wed, 3 Jan 2024 11:19:51 +0000 (12:19 +0100)]
Use SPDX license identifiers

21 months agoUpdate copyright years
Simon Ruderich [Wed, 3 Jan 2024 11:15:17 +0000 (12:15 +0100)]
Update copyright years

21 months agoci: run govulncheck
Simon Ruderich [Wed, 3 Jan 2024 10:33:27 +0000 (11:33 +0100)]
ci: run govulncheck

21 months agoci: update static checkers
Simon Ruderich [Wed, 3 Jan 2024 10:32:46 +0000 (11:32 +0100)]
ci: update static checkers

2 years agoremote: add and improve comments
Simon Ruderich [Sun, 15 Jan 2023 09:58:36 +0000 (10:58 +0100)]
remote: add and improve comments

2 years agoREADME: add missing highlight
Simon Ruderich [Sun, 15 Jan 2023 09:57:28 +0000 (10:57 +0100)]
README: add missing highlight

2 years agogo fmt
Simon Ruderich [Sun, 15 Jan 2023 09:50:17 +0000 (10:50 +0100)]
go fmt

2 years agoremote: support creating files with missing parents in dry-run
Simon Ruderich [Sun, 15 Jan 2023 09:44:12 +0000 (10:44 +0100)]
remote: support creating files with missing parents in dry-run

The actual run worked fine but the dry-run failed because the parent
directory does not exist at that point.

2 years agoUpdate copyright years
Simon Ruderich [Sun, 15 Jan 2023 09:23:33 +0000 (10:23 +0100)]
Update copyright years

3 years agoci: use fixed versions for staticcheck and golangci-lint
Simon Ruderich [Mon, 8 Aug 2022 05:48:28 +0000 (07:48 +0200)]
ci: use fixed versions for staticcheck and golangci-lint

The latest version of golangci-lint only supports Go 1.19 which is not
available yet on all CI targets.

Makes the CI deterministic and prevents failures if the checks change.

3 years agosync: never remove packages during installation on Debian
Simon Ruderich [Tue, 26 Apr 2022 05:54:27 +0000 (07:54 +0200)]
sync: never remove packages during installation on Debian

Guard against package conflicts to remove packages. The user must first
remove the conflicting package to prevent accidental removals.

3 years agotests: use consistent order of safcm.File struct members
Simon Ruderich [Sun, 6 Mar 2022 09:04:45 +0000 (10:04 +0100)]
tests: use consistent order of safcm.File struct members

3 years agoUpdate copyright years
Simon Ruderich [Sun, 6 Mar 2022 09:03:21 +0000 (10:03 +0100)]
Update copyright years

3 years agoci/run: run golangci-lint
Simon Ruderich [Thu, 23 Dec 2021 17:21:35 +0000 (18:21 +0100)]
ci/run: run golangci-lint

Currently golangci-lint doesn't call all staticcheck linters:
https://github.com/golangci/golangci-lint/issues/357

3 years agoRemove superfluous struct names
Simon Ruderich [Thu, 23 Dec 2021 17:07:50 +0000 (18:07 +0100)]
Remove superfluous struct names

Found by golangci-lint's gofmt linter

3 years agogo fmt
Simon Ruderich [Tue, 7 Dec 2021 09:41:55 +0000 (10:41 +0100)]
go fmt

3 years agoci/run: use `go install` to install staticcheck
Simon Ruderich [Tue, 7 Dec 2021 09:34:16 +0000 (10:34 +0100)]
ci/run: use `go install` to install staticcheck

Go 1.18+ will not install software with `go get` anymore.

3 years agoci: fix Gitlab-CI build with recent Sid versions
Simon Ruderich [Tue, 7 Dec 2021 09:24:39 +0000 (10:24 +0100)]
ci: fix Gitlab-CI build with recent Sid versions

The package golang-1.16 is no longer available. Sid now uses
golang-1.17, making the old workaround unnecessary.

4 years agoUpdate golang.org/x/sys and remove OpenBSD workarounds
Simon Ruderich [Tue, 8 Jun 2021 06:11:43 +0000 (08:11 +0200)]
Update golang.org/x/sys and remove OpenBSD workarounds

The latest version of golang.org/x/sys contains AT_REMOVEDIR also on
OpenBSD.

4 years agoremote: retain setgid/sticky when temporarily chmodding directories
Simon Ruderich [Thu, 3 Jun 2021 08:46:51 +0000 (10:46 +0200)]
remote: retain setgid/sticky when temporarily chmodding directories

4 years agoremote: permit syncing relative paths with leading dot
Simon Ruderich [Wed, 2 Jun 2021 05:57:09 +0000 (07:57 +0200)]
remote: permit syncing relative paths with leading dot

These are normally not used by safcm but the remote should still support
them.

4 years agoremote: go fmt and rewrap comment
Simon Ruderich [Tue, 1 Jun 2021 06:18:48 +0000 (08:18 +0200)]
remote: go fmt and rewrap comment

4 years agoremote: remove SyncPath()
Simon Ruderich [Tue, 1 Jun 2021 06:17:49 +0000 (08:17 +0200)]
remote: remove SyncPath()

Not removed in 2804606 (remote: guard against symlinks in earlier path
components, 2021-06-01) to make the diff more readable.

4 years agoremote: rename files_windows.go to files_compat_windows.go
Simon Ruderich [Tue, 1 Jun 2021 06:00:03 +0000 (08:00 +0200)]
remote: rename files_windows.go to files_compat_windows.go

4 years agoremote: guard against symlinks in earlier path components
Simon Ruderich [Tue, 1 Jun 2021 05:59:59 +0000 (07:59 +0200)]
remote: guard against symlinks in earlier path components

This was only an issue when syncing files to directories where other
users have write access to the parent directory. For example when
copying files to /home/user/.ssh/authorized_keys the user could replace
.ssh with a symlink which permitted overwriting authorized_keys anywhere
on the system.

Fix possible attacks by using *at syscalls and disallowing symlinks in
all path components except for the last of synced paths. Syncing
symlinks is obviously still permitted.

4 years agosafcm: add commit date to version output
Simon Ruderich [Mon, 31 May 2021 20:31:13 +0000 (22:31 +0200)]
safcm: add commit date to version output

4 years ago.builds: openbsd/latest updated to 6.9, remove manual Go download
Simon Ruderich [Sat, 29 May 2021 15:34:57 +0000 (17:34 +0200)]
.builds: openbsd/latest updated to 6.9, remove manual Go download

4 years agoremote: use defer to replace multiple dh.Close()
Simon Ruderich [Wed, 26 May 2021 07:20:04 +0000 (09:20 +0200)]
remote: use defer to replace multiple dh.Close()

4 years agoremote: remove double Close() on error in WriteTemp()
Simon Ruderich [Tue, 25 May 2021 06:43:00 +0000 (08:43 +0200)]
remote: remove double Close() on error in WriteTemp()

4 years agoremote: treat paths as slash separated in triggerPaths()
Simon Ruderich [Sun, 23 May 2021 10:33:06 +0000 (12:33 +0200)]
remote: treat paths as slash separated in triggerPaths()

Remotes are only supported on UNIX systems which use slashes as path
separators so this had no direct effect. Change it to make the code more
obvious.

This was forgotten in afb7e8e (safcm: use only slash separated paths for
the configuration, 2021-05-13).

4 years agosafcm: move logEvent() to frontend package
Simon Ruderich [Tue, 18 May 2021 16:51:47 +0000 (18:51 +0200)]
safcm: move logEvent() to frontend package

4 years agofrontend: add Loop.HostSyncMsg()
Simon Ruderich [Tue, 18 May 2021 16:36:11 +0000 (18:36 +0200)]
frontend: add Loop.HostSyncMsg()

4 years agofrontend: add Loop.HostInfoMsg()
Simon Ruderich [Tue, 18 May 2021 16:36:06 +0000 (18:36 +0200)]
frontend: add Loop.HostInfoMsg()

4 years agosafcm: move sync.sendRecv to frontend package
Simon Ruderich [Tue, 18 May 2021 16:24:02 +0000 (18:24 +0200)]
safcm: move sync.sendRecv to frontend package

4 years agosafcm: move sync_changes.go and term.go to frontend package
Simon Ruderich [Tue, 18 May 2021 16:15:23 +0000 (18:15 +0200)]
safcm: move sync_changes.go and term.go to frontend package

4 years agosafcm: add ParseLogLevel()
Simon Ruderich [Tue, 18 May 2021 15:52:14 +0000 (17:52 +0200)]
safcm: add ParseLogLevel()

4 years agogo fmt
Simon Ruderich [Tue, 18 May 2021 15:46:59 +0000 (17:46 +0200)]
go fmt

4 years agoMove synchronization loop into new package frontend
Simon Ruderich [Tue, 18 May 2021 15:46:56 +0000 (17:46 +0200)]
Move synchronization loop into new package frontend

This is in preparation for other programs (besides cmd/safcm) using the
safcm library. To reduce code duplication useful functions will be
provided by the frontend package. Its use is optional. All core
functionality is provided by the regular safcm packages.

The logging setup was slightly modified. Log messages are now no longer
filtered by Sync.log() but by the new log function Loop.LogEventFunc (or
its implementation logEvent()). This is also the reason why one test was
removed from sync_sync_test.go which is no longer relevant.

4 years agoMove implementation of cmd/safcm-remote/ to remote/
Simon Ruderich [Tue, 18 May 2021 10:29:48 +0000 (12:29 +0200)]
Move implementation of cmd/safcm-remote/ to remote/

This permits users of the safcm library to easily "implement"
`safcm-remote` simply by calling safcm/remote.Main(). They cannot use
the existing cmd/safcm-remote/ because the source tree is not directly
available when importing the library.

4 years agoMove embedded remote helpers to cmd/safcm/
Simon Ruderich [Tue, 18 May 2021 09:03:05 +0000 (11:03 +0200)]
Move embedded remote helpers to cmd/safcm/

To permit using safcm as an actual library the helpers must be passed to
rpc.DialSSH() and not directly embedded.

4 years agosafcm: don't hang on error before a connection is established
Simon Ruderich [Tue, 18 May 2021 08:50:43 +0000 (10:50 +0200)]
safcm: don't hang on error before a connection is established

4 years agorpc: use SSHConfig struct as argument to DialSSH()
Simon Ruderich [Tue, 18 May 2021 08:10:09 +0000 (10:10 +0200)]
rpc: use SSHConfig struct as argument to DialSSH()

In preparation to add more arguments to DialSSH().

4 years agoconfig: config.yaml: add global "ssh_user" option
Simon Ruderich [Mon, 17 May 2021 06:37:23 +0000 (08:37 +0200)]
config: config.yaml: add global "ssh_user" option

This option is used as default value when the host option "ssh_user" is
empty. Like the host option it defaults to an empty value which tells
`ssh` to use the current user.

4 years agoci: build for Windows
Simon Ruderich [Sun, 16 May 2021 20:42:51 +0000 (22:42 +0200)]
ci: build for Windows

Only added to Gitlab-CI because we just want to test if building works
in general.

4 years agosafcm: add experimental support to sync from Windows hosts
Simon Ruderich [Thu, 13 May 2021 11:55:47 +0000 (13:55 +0200)]
safcm: add experimental support to sync from Windows hosts

This is _very_ experimental. The testsuite doesn't yet run on Windows
and only a few manual tests were run. Basically this is only present
because it was used to verify our changes to always use slash-separated
paths in the configuration on a real system. It seemed a waste to just
throw it away.

To build the binary for windows use (empty GOFLAGS to disable -race):

    make GOOS=windows GOFLAGS=

4 years agosafcm: use only slash separated paths for the configuration
Simon Ruderich [Thu, 13 May 2021 11:40:54 +0000 (13:40 +0200)]
safcm: use only slash separated paths for the configuration

This change is in preparation to support running synchronizations from
Windows systems. However, Windows remotes won't be supported in the
foreseeable future.

4 years agosafcm: simplify Sync.logf to take the log message as string
Simon Ruderich [Wed, 12 May 2021 06:35:59 +0000 (08:35 +0200)]
safcm: simplify Sync.logf to take the log message as string

logf() is not directly called by regular code which makes the format
string less useful.

Also rename it to log().

4 years agoConsistently use %v when (s)printing errors
Simon Ruderich [Wed, 12 May 2021 06:32:51 +0000 (08:32 +0200)]
Consistently use %v when (s)printing errors

Most of the code already used %v.

4 years agosync: go fmt
Simon Ruderich [Wed, 12 May 2021 06:25:08 +0000 (08:25 +0200)]
sync: go fmt

4 years agosync: shorten log messages by removing "info/sync remote:" prefix
Simon Ruderich [Wed, 12 May 2021 06:22:17 +0000 (08:22 +0200)]
sync: shorten log messages by removing "info/sync remote:" prefix

The prefix provides little value as it already obvious what's happening
on the remote side and in which phase (info/sync). Keeping the log
messages shorter helps the user to focus on the important parts of the
message.

4 years agosync: simplify LogFunc to take the log message as string
Simon Ruderich [Wed, 12 May 2021 06:17:39 +0000 (08:17 +0200)]
sync: simplify LogFunc to take the log message as string

LogFunc is not directly called by regular code which makes the format
string less useful.

4 years agosync: replace log.Logger interface with struct
Simon Ruderich [Wed, 12 May 2021 06:14:26 +0000 (08:14 +0200)]
sync: replace log.Logger interface with struct

PrefixLogger is the only implementation of Logger. Simply remove the
interface and rename PrefixLogger to Logger.

4 years agoMakefile: add lint target to run shellcheck
Simon Ruderich [Wed, 12 May 2021 05:40:56 +0000 (07:40 +0200)]
Makefile: add lint target to run shellcheck

4 years agosync: remove "detected" log message in packages/services
Simon Ruderich [Sun, 9 May 2021 19:19:42 +0000 (21:19 +0200)]
sync: remove "detected" log message in packages/services

Don't waste one full log message to show the detected system. Instead,
append it to an existing log message.

Reorder log call in syncPackagesDebian() so the log message comes before
calling debianInstalledPackages(). This way errors from this function
show clearly where they originate.

4 years agoremote: tests: hide testRunner functions in test output
Simon Ruderich [Sun, 9 May 2021 18:44:02 +0000 (20:44 +0200)]
remote: tests: hide testRunner functions in test output

This is not perfect because they are called from files like
cmd/safcm-remote/sync/commands.go which is not very helpful to figure
out which test case failed. However, it's better than showing
cmd/safcm-remote/sync/sync_test.go which was the previous behavior.

4 years agotests: improve another comment
Simon Ruderich [Sun, 9 May 2021 18:38:37 +0000 (20:38 +0200)]
tests: improve another comment

4 years agochanges: add "(hidden)" to commands with no output and quiet mode
Simon Ruderich [Sun, 9 May 2021 18:20:16 +0000 (20:20 +0200)]
changes: add "(hidden)" to commands with no output and quiet mode

This should make it more obvious why these commands are not shown.

4 years agosafcm: tests: remove empty line
Simon Ruderich [Sun, 9 May 2021 18:15:09 +0000 (20:15 +0200)]
safcm: tests: remove empty line

4 years agorpc: remove empty line
Simon Ruderich [Sun, 9 May 2021 18:14:39 +0000 (20:14 +0200)]
rpc: remove empty line

4 years agoconfig: disallow negative permissions
Simon Ruderich [Sun, 9 May 2021 18:02:31 +0000 (20:02 +0200)]
config: disallow negative permissions

4 years agorpc: replace append to sshOpts with assignment in DialSSH()
Simon Ruderich [Sun, 9 May 2021 17:51:02 +0000 (19:51 +0200)]
rpc: replace append to sshOpts with assignment in DialSSH()

sshOpts is empty by default and assigned only once. Don't suggest that
this line is supposed to add to an existing value.

4 years agosafcm: shorten error message on file conflict
Simon Ruderich [Sun, 9 May 2021 10:55:54 +0000 (12:55 +0200)]
safcm: shorten error message on file conflict

It's obvious that the message talks about "files" because the path is
given immediately afterwards.

4 years agosafcm: use better variable name in hostsToSync()
Simon Ruderich [Sun, 9 May 2021 10:47:40 +0000 (12:47 +0200)]
safcm: use better variable name in hostsToSync()

Having nameMatched and hostMatched is confusing. Follow the comment and
use hostAdded which describes the meaning more clearly.

4 years agosafcm: don't color output if stderr is redirected
Simon Ruderich [Sun, 9 May 2021 10:46:18 +0000 (12:46 +0200)]
safcm: don't color output if stderr is redirected

All log messages are printed to stderr. It's confusing to still get
colored output when redirecting stderr to a file; only redirecting
stdout as well fixed this.

4 years agochanges: change dry-run messages to use "will"
Simon Ruderich [Sun, 9 May 2021 10:44:29 +0000 (12:44 +0200)]
changes: change dry-run messages to use "will"

Don't suggest that the change already took place. "dry-run" is still
printed to make it clear why no changes were made.

4 years agochanges: tests: remove output for dry-run commands
Simon Ruderich [Sun, 9 May 2021 10:39:30 +0000 (12:39 +0200)]
changes: tests: remove output for dry-run commands

Commands during a dry-run have no output. Don't use incorrect test
input.

4 years agoconfig: tests: fix typo in group name
Simon Ruderich [Sun, 9 May 2021 10:34:44 +0000 (12:34 +0200)]
config: tests: fix typo in group name

4 years agoconfig: return map from TransitivelyDetectedGroups()
Simon Ruderich [Sun, 9 May 2021 10:32:53 +0000 (12:32 +0200)]
config: return map from TransitivelyDetectedGroups()

This is less clean than the original slice of strings. However, it
removes unnecessary code as the caller requires a map instead of a
slice.

4 years agoconfig: use more explicit variable name in ResolveHostGroups()
Simon Ruderich [Sun, 9 May 2021 10:31:26 +0000 (12:31 +0200)]
config: use more explicit variable name in ResolveHostGroups()

4 years agoconfig: rewrap line in ResolveHostGroups()
Simon Ruderich [Sun, 9 May 2021 10:31:08 +0000 (12:31 +0200)]
config: rewrap line in ResolveHostGroups()

4 years agoconfig: tests: replace FullPermToFileMode() with fs constants
Simon Ruderich [Sun, 9 May 2021 10:29:08 +0000 (12:29 +0200)]
config: tests: replace FullPermToFileMode() with fs constants

FullPermToFileMode() is necessary in a few places but the tests should
use the common way in Go to set permissions. This is less confusing for
the reader.

4 years agosync: remove duplicate code in triggerPaths()
Simon Ruderich [Sun, 9 May 2021 10:28:33 +0000 (12:28 +0200)]
sync: remove duplicate code in triggerPaths()

4 years agosync: include size in binary "diff"
Simon Ruderich [Sun, 9 May 2021 10:27:28 +0000 (12:27 +0200)]
sync: include size in binary "diff"

4 years agosync: tests: use variable to reduce line wrapping
Simon Ruderich [Sun, 9 May 2021 10:24:12 +0000 (12:24 +0200)]
sync: tests: use variable to reduce line wrapping

4 years agosync: tests: use "..." instead of `...` for regular strings
Simon Ruderich [Sun, 9 May 2021 10:20:39 +0000 (12:20 +0200)]
sync: tests: use "..." instead of `...` for regular strings

4 years agosync: tests: use strict perm for os.WriteFile() in CreateFile()
Simon Ruderich [Sun, 9 May 2021 10:15:58 +0000 (12:15 +0200)]
sync: tests: use strict perm for os.WriteFile() in CreateFile()

This parameter is modified by the umask. The proper permissions are set
by os.Chmod() afterwards. Don't confuse the reader by using a value
which is not relevant.

4 years agosync: tests: wrap overlong line
Simon Ruderich [Sun, 9 May 2021 10:15:42 +0000 (12:15 +0200)]
sync: tests: wrap overlong line

4 years agosync: tests: use CreateDirectoryExists()
Simon Ruderich [Sun, 9 May 2021 10:14:16 +0000 (12:14 +0200)]
sync: tests: use CreateDirectoryExists()

4 years agosync: tests: check return value of setDefaults()
Simon Ruderich [Sun, 9 May 2021 10:13:37 +0000 (12:13 +0200)]
sync: tests: check return value of setDefaults()

4 years agosync: tests: properly scope err variable
Simon Ruderich [Sun, 9 May 2021 10:12:22 +0000 (12:12 +0200)]
sync: tests: properly scope err variable

4 years agosync: tests: go fmt
Simon Ruderich [Sun, 9 May 2021 09:42:31 +0000 (11:42 +0200)]
sync: tests: go fmt

4 years agosync: tests: rename triggers to expTriggers
Simon Ruderich [Sun, 9 May 2021 09:41:57 +0000 (11:41 +0200)]
sync: tests: rename triggers to expTriggers

4 years agosafcm: tests: test detected groups with leading/trailing space
Simon Ruderich [Sun, 9 May 2021 09:38:42 +0000 (11:38 +0200)]
safcm: tests: test detected groups with leading/trailing space

4 years agosafcm: go fmt
Simon Ruderich [Sun, 9 May 2021 09:38:27 +0000 (11:38 +0200)]
safcm: go fmt

4 years agosafcm: strip invalid characters from detected os/arch groups
Simon Ruderich [Sun, 9 May 2021 09:36:44 +0000 (11:36 +0200)]
safcm: strip invalid characters from detected os/arch groups

Handle them like any other detected group because the remote can send
invalid values. The current code can handle arbitrary group names just
fine but it's better to treat all untrusted input the same.

4 years agoImprove and add comments
Simon Ruderich [Sun, 9 May 2021 08:10:56 +0000 (10:10 +0200)]
Improve and add comments

4 years agoci: suppress shellcheck warnings
Simon Ruderich [Sun, 9 May 2021 08:03:34 +0000 (10:03 +0200)]
ci: suppress shellcheck warnings

$flags can contain multiple flags and we must expand them here.

4 years agoREADME: mention root/wheel on BSD systems
Simon Ruderich [Sun, 9 May 2021 08:02:35 +0000 (10:02 +0200)]
README: mention root/wheel on BSD systems

4 years agoREADME: fix typo
Simon Ruderich [Sun, 9 May 2021 08:02:30 +0000 (10:02 +0200)]
README: fix typo

4 years agotests: run commands without side effects in end-to-end tests
Simon Ruderich [Sat, 8 May 2021 08:20:57 +0000 (10:20 +0200)]
tests: run commands without side effects in end-to-end tests

4 years agoREADME: multiple improvements
Simon Ruderich [Thu, 29 Apr 2021 05:43:05 +0000 (07:43 +0200)]
README: multiple improvements

4 years agotests: add end-to-end test with configuration without any changes
Simon Ruderich [Wed, 28 Apr 2021 10:29:50 +0000 (12:29 +0200)]
tests: add end-to-end test with configuration without any changes

4 years agosync: run most tests which modify the host only in CI
Simon Ruderich [Wed, 28 Apr 2021 10:26:18 +0000 (12:26 +0200)]
sync: run most tests which modify the host only in CI

This is especially important in case the user executes the tests as root
(no recommended but not prevented either). Permissions on paths like /
or /tmp which differ from those expected by the test could otherwise be
modified by the tests.

However, the end-to-end SSH tests which write /tmp/safcm-remote-$uid
(but no other paths) are still run so we get proper coverage of basic
features.

4 years agotests: use filetest.CreateFifo() in config tests
Simon Ruderich [Wed, 28 Apr 2021 06:29:49 +0000 (08:29 +0200)]
tests: use filetest.CreateFifo() in config tests

4 years agosync: remove duplicate "priority" from group priority log message
Simon Ruderich [Wed, 28 Apr 2021 05:57:52 +0000 (07:57 +0200)]
sync: remove duplicate "priority" from group priority log message

Now that the configuration option is called "group_priority" we can
remove the second "priority" and spell out "descending" (takes less
space than before).