Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 1 | # This test should cover https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=289 testcase |
| 2 | # Note that the image under test must have logrotate installed |
| 3 | |
| 4 | from oeqa.runtime.case import OERuntimeTestCase |
| 5 | from oeqa.core.decorator.depends import OETestDepends |
| 6 | from oeqa.core.decorator.oeid import OETestID |
| 7 | from oeqa.runtime.decorator.package import OEHasPackage |
| 8 | |
| 9 | class LogrotateTest(OERuntimeTestCase): |
| 10 | |
| 11 | @classmethod |
Andrew Geissler | 99467da | 2019-02-25 18:54:23 -0600 | [diff] [blame] | 12 | def setUpClass(cls): |
| 13 | cls.tc.target.run('cp /etc/logrotate.d/wtmp $HOME/wtmp.oeqabak') |
| 14 | |
| 15 | @classmethod |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 16 | def tearDownClass(cls): |
Andrew Geissler | 99467da | 2019-02-25 18:54:23 -0600 | [diff] [blame] | 17 | cls.tc.target.run('mv -f $HOME/wtmp.oeqabak /etc/logrotate.d/wtmp && rm -rf $HOME/logrotate_dir') |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 18 | |
| 19 | @OETestID(1544) |
| 20 | @OETestDepends(['ssh.SSHTest.test_ssh']) |
| 21 | @OEHasPackage(['logrotate']) |
| 22 | def test_1_logrotate_setup(self): |
| 23 | status, output = self.target.run('mkdir $HOME/logrotate_dir') |
| 24 | msg = 'Could not create logrotate_dir. Output: %s' % output |
| 25 | self.assertEqual(status, 0, msg = msg) |
| 26 | |
| 27 | cmd = ('sed -i "s#wtmp {#wtmp {\\n olddir $HOME/logrotate_dir#"' |
Brad Bishop | 1a4b7ee | 2018-12-16 17:11:34 -0800 | [diff] [blame] | 28 | ' /etc/logrotate.d/wtmp') |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 29 | status, output = self.target.run(cmd) |
Brad Bishop | 1a4b7ee | 2018-12-16 17:11:34 -0800 | [diff] [blame] | 30 | msg = ('Could not write to logrotate.d/wtmp file. Status and output: ' |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 31 | ' %s and %s' % (status, output)) |
| 32 | self.assertEqual(status, 0, msg = msg) |
| 33 | |
| 34 | @OETestID(1542) |
| 35 | @OETestDepends(['logrotate.LogrotateTest.test_1_logrotate_setup']) |
| 36 | def test_2_logrotate(self): |
| 37 | status, output = self.target.run('logrotate -f /etc/logrotate.conf') |
| 38 | msg = ('logrotate service could not be reloaded. Status and output: ' |
| 39 | '%s and %s' % (status, output)) |
| 40 | self.assertEqual(status, 0, msg = msg) |
| 41 | |
| 42 | _, output = self.target.run('ls -la $HOME/logrotate_dir/ | wc -l') |
| 43 | msg = ('new logfile could not be created. List of files within log ' |
| 44 | 'directory: %s' % ( |
| 45 | self.target.run('ls -la $HOME/logrotate_dir')[1])) |
| 46 | self.assertTrue(int(output)>=3, msg = msg) |