Commit af3428ce authored by Martin Pitt's avatar Martin Pitt
Browse files

Add boot-and-services autopkgtest

Check booting with systemd-sysv and that the most crucial services behave as
parent 4f42c7a7
......@@ -2,6 +2,8 @@ systemd (215-7) UNRELEASED; urgency=medium
[ Martin Pitt ]
* Add myself to Uploaders:.
* Add boot-and-services autopkgtest: Check booting with systemd-sysv and
that the most crucial services behave as expected.
[ Jon Severinsson]
* Add /run/shm -> /dev/shm symlink in debian/tmpfiles.d/debian.conf. This
# autopkgtest check: Boot with systemd and check critical desktop services
# (C) 2014 Canonical Ltd.
# Author: Martin Pitt <>
import sys
import os
import unittest
import subprocess
class ServicesTest(unittest.TestCase):
'''Check that expected services are running'''
def test_0_init(self):
'''Verify that init is systemd'''
self.assertIn('systemd', os.readlink('/proc/1/exe'))
def test_lightdm(self):
out = subprocess.check_output(['ps', 'u', '-C', 'lightdm'])
self.assertIn(b'lightdm --session', out)
out = subprocess.check_output(['ps', 'u', '-C', 'Xorg'])
self.assertIn(b':0', out)
def test_dbus(self):
out = subprocess.check_output(
['dbus-send', '--print-reply', '--system',
'--dest=org.freedesktop.DBus', '/', 'org.freedesktop.DBus.GetId'])
self.assertIn(b'string "', out)
def test_network_manager(self):
# 0.9.10 changed the command name
_help = subprocess.check_output(['nmcli', '--help'],
if b' g[eneral]' in _help:
out = subprocess.check_output(['nmcli', 'general'])
out = subprocess.check_output(['nmcli', 'nm'])
self.assertIn(b'enabled', out)
def test_cron(self):
out = subprocess.check_output(['ps', 'u', '-C', 'cron'])
self.assertIn(b'root', out)
def test_logind(self):
out = subprocess.check_output(['loginctl'])
self.assertNotEqual(b'', out)
def test_rsyslog(self):
out = subprocess.check_output(['ps', 'u', '-C', 'rsyslogd'])
self.assertIn(b'bin/rsyslogd', out)
with open('/var/log/syslog') as f:
log =
# has kernel messages
self.assertRegex(log, 'kernel:.*[cC]ommand line:')
# has init messages
self.assertRegex(log, 'systemd.*Reached target Default')
# has other services
self.assertRegex(log, 'NetworkManager.*:')
def test_udev(self):
out = subprocess.check_output(['udevadm', 'info', '--export-db'])
self.assertIn(b'\nP: /devices/', out)
# Helper methods
def active_unit(self, unit):
'''Check that given unit is active'''
out = subprocess.check_output(['systemctl', 'status', unit])
self.assertIn(b'active (running)', out)
class JournalTest(unittest.TestCase):
'''Check journal functionality'''
def test_no_options(self):
out = subprocess.check_output(['journalctl'])
# has kernel messages
self.assertRegex(out, b'kernel:.*[cC]ommand line:')
# has init messages
self.assertRegex(out, b'systemd.*Reached target Default')
# has other services
self.assertRegex(out, b'NetworkManager.*:.*starting')
def test_log_for_service(self):
out = subprocess.check_output(
['journalctl', '_SYSTEMD_UNIT=NetworkManager.service'])
self.assertRegex(out, b'NetworkManager.*:.*starting')
self.assertNotIn(b'kernel:', out)
self.assertNotIn(b'systemd:', out)
def boot_with_systemd():
'''Reboot with systemd as init
In case something else is currently running in the testbed
if['systemctl', 'status'], stdout=subprocess.PIPE,
stderr=subprocess.PIPE) != 0:
print('Installing systemd-sysv and rebooting...')
subprocess.check_call('apt-get -y install systemd-sysv 2>&1',
subprocess.check_call(['autopkgtest-reboot', 'boot-systemd'])
if __name__ == '__main__':
if not os.getenv('ADT_REBOOT_MARK'):
......@@ -7,3 +7,7 @@ Depends: libsystemd-login-dev, build-essential, pkg-config
Tests: python3
Depends: python3-systemd
Tests: boot-and-services
Depends: lightdm, cron, network-manager
Restrictions: needs-root, isolation-machine, needs-recommends, breaks-testbed
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment