mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 12:59:02 +02:00

When using syslog-ng as the syslog provider, oe_syslog test case fails because it cannot find the syslog daemon. This is because it greps for 'syslogd' but syslog-ng's daemon is 'syslog-ng'. So fix it to check both 'syslogd' and 'syslog-ng'. Also, when the test case fails, what I get is: | AssertionError: 1 != 0 : No syslogd process; ps output: <empty here> This does not help user. The output is actually from the 'PS | GREP' command. And when the 'PS | GREP' command fails, the output is always empty. So also fix this problem. After the change, it looks like: | AssertionError: False is not true : No syslog daemon process; ps output: | PID USER VSZ STAT COMMAND | 1 root 16476 S {systemd} /sbin/init | 2 root 0 SW [kthreadd] | 3 root 0 IW [kworker/0:0] ... (From OE-Core rev: b180fbd9d93db1c6351e183fbc08fc81cdc240c0) Signed-off-by: Chen Qi <Qi.Chen@windriver.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
69 lines
3.0 KiB
Python
69 lines
3.0 KiB
Python
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", "rsyslog", "syslog-ng"])
|
|
def test_syslog_running(self):
|
|
status, output = self.target.run(self.tc.target_cmds['ps'])
|
|
msg = "Failed to execute %s" % self.tc.target_cmds['ps']
|
|
self.assertEqual(status, 0, msg=msg)
|
|
msg = "No syslog daemon process; %s output:\n%s" % (self.tc.target_cmds['ps'], output)
|
|
hasdaemon = "syslogd" in output or "syslog-ng" in output
|
|
self.assertTrue(hasdaemon, 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(["busybox-syslog"])
|
|
@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')
|