]>
git.proxmox.com Git - systemd.git/blob - test/test-shutdown.py
e181f976bea580e8fb5ed0f84b568c8a1e6dd257
2 # SPDX-License-Identifier: LGPL-2.1-or-later
15 logger
= logging
.getLogger("test-shutdown")
17 logger
.info("spawning test")
18 console
= pexpect
.spawn(args
.command
, args
.arg
, env
={
20 }, encoding
='utf-8', timeout
=30)
23 console
.logfile
= sys
.stdout
25 logger
.debug("child pid %d", console
.pid
)
28 logger
.info("waiting for login prompt")
29 console
.expect('H login: ', 10)
31 logger
.info("log in and start screen")
32 console
.sendline('root')
33 console
.expect('bash.*# ', 10)
34 console
.sendline('screen')
35 console
.expect('screen0 ', 10)
36 console
.sendcontrol('a')
38 console
.expect('screen1 ', 10)
42 console
.sendline('tty')
43 console
.expect(r
'/dev/(pts/\d+)')
44 pty
= console
.match
.group(1)
45 logger
.info("window 1 at line %s", pty
)
47 logger
.info("schedule reboot")
48 console
.sendline('shutdown -r')
49 console
.expect("Reboot scheduled for (?P<date>.*), use 'shutdown -c' to cancel", 2)
50 date
= console
.match
.group('date')
51 logger
.info("reboot scheduled for %s", date
)
53 console
.sendcontrol('a')
55 logger
.info("verify broadcast message")
56 console
.expect('Broadcast message from root@H on %s' % pty
, 2)
57 console
.expect('The system will reboot at %s' % date
, 2)
59 logger
.info("check show output")
60 console
.sendline('shutdown --show')
61 console
.expect("Reboot scheduled for %s, use 'shutdown -c' to cancel" % date
, 2)
63 logger
.info("cancel shutdown")
64 console
.sendline('shutdown -c')
65 console
.sendcontrol('a')
67 console
.expect('System shutdown has been cancelled', 2)
69 logger
.info("call for reboot")
70 console
.sendline('sleep 10; shutdown -r now')
71 console
.sendcontrol('a')
73 console
.expect("The system will reboot now!", 12)
75 logger
.info("waiting for reboot")
77 console
.expect('H login: ', 60)
78 console
.sendline('root')
79 console
.expect('bash.*# ', 10)
81 console
.sendline('> /testok')
83 logger
.info("power off")
84 console
.sendline('poweroff')
86 logger
.info("expect termination now")
87 console
.expect(pexpect
.EOF
)
90 except Exception as e
:
92 logger
.info("killing child pid %d", console
.pid
)
93 console
.terminate(force
=True)
98 parser
= argparse
.ArgumentParser(description
='test logind shutdown feature')
99 parser
.add_argument("-v", "--verbose", action
="store_true", help="verbose")
100 parser
.add_argument("command", help="command to run")
101 parser
.add_argument("arg", nargs
='*', help="args for command")
103 args
= parser
.parse_args()
106 level
= logging
.DEBUG
110 logging
.basicConfig(level
=level
)
114 if __name__
== '__main__':