mirror of
https://github.com/SebastianWendel/nixpkgs.git
synced 2024-09-20 04:19:00 +02:00
4d12b79cd7
logrotate.timer is enough for rotating logs. Enabling logrotate.service would make the service start on every configuration switch, leading to tests failure when logrotate is enabled. Also update test to make sure the timer is active and runs the service on date change.
37 lines
1.1 KiB
Nix
37 lines
1.1 KiB
Nix
# Test logrotate service works and is enabled by default
|
|
|
|
import ./make-test-python.nix ({ pkgs, ...} : rec {
|
|
name = "logrotate";
|
|
meta = with pkgs.lib.maintainers; {
|
|
maintainers = [ martinetd ];
|
|
};
|
|
|
|
# default machine
|
|
machine = { ... }: {
|
|
};
|
|
|
|
testScript =
|
|
''
|
|
with subtest("whether logrotate works"):
|
|
machine.succeed(
|
|
# we must rotate once first to create logrotate stamp
|
|
"systemctl start logrotate.service")
|
|
# we need to wait for console text once here to
|
|
# clear console buffer up to this point for next wait
|
|
machine.wait_for_console_text('logrotate.service: Deactivated successfully')
|
|
|
|
machine.succeed(
|
|
# wtmp is present in default config.
|
|
"rm -f /var/log/wtmp*",
|
|
"echo test > /var/log/wtmp",
|
|
|
|
# move into the future and check rotation.
|
|
"date -s 'now + 1 month + 1 day'")
|
|
machine.wait_for_console_text('logrotate.service: Deactivated successfully')
|
|
machine.succeed(
|
|
# check rotate worked
|
|
"[ -e /var/log/wtmp.1 ]",
|
|
)
|
|
'';
|
|
})
|