nixpkgs/nixos/tests/incron.nix

53 lines
1.5 KiB
Nix
Raw Normal View History

2019-11-09 19:18:42 +00:00
import ./make-test-python.nix ({ pkgs, lib, ... }:
{
name = "incron";
meta.maintainers = [ lib.maintainers.aanderse ];
2022-03-20 23:15:30 +00:00
nodes.machine =
{ ... }:
{ services.incron.enable = true;
services.incron.extraPackages = [ pkgs.coreutils ];
services.incron.systab = ''
/test IN_CREATE,IN_MODIFY,IN_CLOSE_WRITE,IN_MOVED_FROM,IN_MOVED_TO echo "$@/$# $%" >> /root/incron.log
'';
# ensure the directory to be monitored exists before incron is started
system.activationScripts.incronTest = ''
mkdir /test
'';
};
testScript = ''
2019-11-09 19:18:42 +00:00
start_all()
2019-11-09 19:18:42 +00:00
machine.wait_for_unit("multi-user.target")
machine.wait_for_unit("incron.service")
2019-11-09 19:18:42 +00:00
machine.succeed("test -d /test")
# create some activity for incron to monitor
2019-11-09 19:18:42 +00:00
machine.succeed("touch /test/file")
machine.succeed("echo foo >> /test/file")
machine.succeed("mv /test/file /root")
machine.succeed("mv /root/file /test")
2019-11-09 19:18:42 +00:00
machine.sleep(1)
# touch /test/file
2019-11-09 19:18:42 +00:00
machine.succeed("grep '/test/file IN_CREATE' /root/incron.log")
# echo foo >> /test/file
2019-11-09 19:18:42 +00:00
machine.succeed("grep '/test/file IN_MODIFY' /root/incron.log")
machine.succeed("grep '/test/file IN_CLOSE_WRITE' /root/incron.log")
# mv /test/file /root
2019-11-09 19:18:42 +00:00
machine.succeed("grep '/test/file IN_MOVED_FROM' /root/incron.log")
# mv /root/file /test
2019-11-09 19:18:42 +00:00
machine.succeed("grep '/test/file IN_MOVED_TO' /root/incron.log")
# ensure something unexpected is not present
2019-11-09 19:18:42 +00:00
machine.fail("grep 'IN_OPEN' /root/incron.log")
'';
})