from oeqa.runtime.case import OERuntimeTestCase from oeqa.core.decorator.depends import OETestDepends from oeqa.core.decorator.oeid import OETestID from oeqa.core.decorator.data import skipIfDataVar from oeqa.runtime.decorator.package import OEHasPackage class SyslogTest(OERuntimeTestCase): @OETestID(201) @OETestDepends(['ssh.SSHTest.test_ssh']) @OEHasPackage(["busybox-syslog", "sysklogd"]) def test_syslog_running(self): cmd = '%s | grep -i [s]yslogd' % self.tc.target_cmds['ps'] status, output = self.target.run(cmd) msg = "No syslogd process; ps output: %s" % output self.assertEqual(status, 0, msg=msg) class SyslogTestConfig(OERuntimeTestCase): @OETestID(1149) @OETestDepends(['oe_syslog.SyslogTest.test_syslog_running']) def test_syslog_logger(self): status, output = self.target.run('logger foobar') msg = "Can't log into syslog. Output: %s " % output self.assertEqual(status, 0, msg=msg) status, output = self.target.run('grep foobar /var/log/messages') if status != 0: if self.tc.td.get("VIRTUAL-RUNTIME_init_manager") == "systemd": status, output = self.target.run('journalctl -o cat | grep foobar') else: status, output = self.target.run('logread | grep foobar') msg = ('Test log string not found in /var/log/messages or logread.' ' Output: %s ' % output) self.assertEqual(status, 0, msg=msg) @OETestID(1150) @OETestDepends(['oe_syslog.SyslogTest.test_syslog_running']) def test_syslog_restart(self): if "systemd" != self.tc.td.get("VIRTUAL-RUNTIME_init_manager", ""): (_, _) = self.target.run('/etc/init.d/syslog restart') else: (_, _) = self.target.run('systemctl restart syslog.service') @OETestID(202) @OETestDepends(['oe_syslog.SyslogTestConfig.test_syslog_logger']) @OEHasPackage(["!sysklogd", "busybox"]) @skipIfDataVar('VIRTUAL-RUNTIME_init_manager', 'systemd', 'Not appropiate for systemd image') def test_syslog_startup_config(self): cmd = 'echo "LOGFILE=/var/log/test" >> /etc/syslog-startup.conf' self.target.run(cmd) status, output = self.target.run('/etc/init.d/syslog restart') msg = ('Could not restart syslog service. Status and output:' ' %s and %s' % (status,output)) self.assertEqual(status, 0, msg) cmd = 'logger foobar && grep foobar /var/log/test' status,output = self.target.run(cmd) msg = 'Test log string not found. Output: %s ' % output self.assertEqual(status, 0, msg=msg) cmd = "sed -i 's#LOGFILE=/var/log/test##' /etc/syslog-startup.conf" self.target.run(cmd) self.target.run('/etc/init.d/syslog restart')