summaryrefslogtreecommitdiff
path: root/unittests
diff options
context:
space:
mode:
authorDylan Baker <dylan@pnwbakers.com>2016-07-25 17:02:11 -0700
committerDylan Baker <dylan@pnwbakers.com>2016-08-05 10:45:04 -0700
commit02a56e804fb08078abc8317f1aed126dda2bcaf1 (patch)
tree649e00cf4192b7e4b23064a12e70008507b6564d /unittests
parentca95cd70b8b7cd7da4e9b0a3aa176a4f1ec1424d (diff)
unittests: port monitoring tests to pytest
Signed-off-by: Dylan Baker <dylanx.c.baker@intel.com>
Diffstat (limited to 'unittests')
-rw-r--r--unittests/framework/test_monitoring.py178
-rw-r--r--unittests/monitoring_tests.py186
2 files changed, 178 insertions, 186 deletions
diff --git a/unittests/framework/test_monitoring.py b/unittests/framework/test_monitoring.py
new file mode 100644
index 000000000..8627d9f7a
--- /dev/null
+++ b/unittests/framework/test_monitoring.py
@@ -0,0 +1,178 @@
+# Copyright (c) 2016 Intel Corporation
+
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+
+# The above copyright notice and this permission notice shall be included in
+# all copies or substantial portions of the Software.
+
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+"""Tests for the monitoring module.
+
+This provides tests for the framework.monitoring modules.
+"""
+
+from __future__ import (
+ absolute_import, division, print_function, unicode_literals
+)
+
+import pytest
+import six
+
+from framework import exceptions
+from framework import monitoring
+from . import skip
+
+# pylint: disable=no-self-use,attribute-defined-outside-init
+
+
+class TestMonitoring(object):
+ """Tests for Monitoring methods."""
+
+ def setup(self):
+ """Setup for TestMonitoring.
+
+ This create a monitoring.Monitoring instance with monitoring disabled
+ to avoid reading the rules in piglit.conf.
+ """
+ self.regex = r'\*ERROR\*|BUG:'
+ self.init_contents = r'foo bar\n'
+ self.no_error_contents = r'foo bar\n'
+ self.error_contents = r'BUG:bar\n'
+ self.monitoring = monitoring.Monitoring(False)
+
+ @skip.linux
+ def test_delete_rule(self, tmpdir):
+ """monitoring.Monitoring: add and delete rule."""
+ p = tmpdir.join('foo')
+ p.write(self.init_contents)
+ self.monitoring.add_rule('error_file',
+ 'file',
+ six.text_type(p),
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ self.monitoring.delete_rule('error_file')
+ p.write(self.error_contents)
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is False
+
+ def test_add_rule_bad_format(self, tmpdir):
+ """monitoring.Monitoring: add non existing type rule."""
+ p = tmpdir.join('foo')
+
+ with pytest.raises(exceptions.PiglitFatalError):
+ self.monitoring.add_rule('error_file_bad_type',
+ 'bad_type',
+ six.text_type(p),
+ self.regex)
+
+ @skip.linux
+ def test_file_error(self, tmpdir):
+ """monitoring.Monitoring: error found on a file."""
+ p = tmpdir.join('foo')
+ p.write(self.init_contents)
+ self.monitoring.add_rule('error_file',
+ 'file',
+ six.text_type(p),
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ p.write(self.error_contents)
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is True
+
+ @skip.linux
+ def test_file_no_error(self, tmpdir):
+ """monitoring.Monitoring: no error found on a file."""
+ p = tmpdir.join('foo')
+ p.write(self.init_contents)
+ self.monitoring.add_rule('no_error_file',
+ 'file',
+ six.text_type(p),
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ p.write(self.no_error_contents)
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is False
+
+ @skip.linux
+ def test_locked_file_error(self, tmpdir):
+ """monitoring.Monitoring: error found on a locked file."""
+ p = tmpdir.join('foo')
+ p.write(self.init_contents)
+ self.monitoring.add_rule('error_locked_file',
+ 'locked_file',
+ six.text_type(p),
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ p.write(self.error_contents)
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is True
+
+ @skip.linux
+ def test_locked_file_no_error(self, tmpdir):
+ """monitoring.Monitoring: no error found on a locked file."""
+ p = tmpdir.join('foo')
+ p.write(self.init_contents)
+ self.monitoring.add_rule('no_error_file',
+ 'locked_file',
+ six.text_type(p),
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ p.write(self.no_error_contents)
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is False
+
+ @skip.linux
+ def test_dmesg_error(self, mocker):
+ """monitoring.Monitoring: error found on the dmesg."""
+ mocker.patch('framework.dmesg.subprocess.check_output',
+ mocker.Mock(return_value=b'[1.0]This\n[2.0]is\n[3.0]dmesg'))
+ self.monitoring.add_rule('no_error_file',
+ 'dmesg',
+ '--level emerg,alert,crit,err',
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ mocker.patch('framework.dmesg.subprocess.check_output',
+ mocker.Mock(return_value=b'[4.0]foo\n[5.0]*ERROR* bar'))
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is True
+
+ @skip.linux
+ def test_dmesg_no_error(self, mocker):
+ """monitoring.Monitoring: no error found on the dmesg."""
+ mocker.patch('framework.dmesg.subprocess.check_output',
+ mocker.Mock(return_value=b'[1.0]This\n[2.0]is\n[3.0]dmesg'))
+ self.monitoring.add_rule('no_error_file',
+ 'dmesg',
+ '--level emerg,alert,crit,err',
+ self.regex)
+ self.monitoring.update_monitoring()
+
+ mocker.patch('framework.dmesg.subprocess.check_output',
+ mocker.Mock(return_value=b'[4.0]foo\n[5.0] bar'))
+ self.monitoring.check_monitoring()
+
+ assert self.monitoring.abort_needed is False
diff --git a/unittests/monitoring_tests.py b/unittests/monitoring_tests.py
deleted file mode 100644
index 3981df0f7..000000000
--- a/unittests/monitoring_tests.py
+++ /dev/null
@@ -1,186 +0,0 @@
-# Copyright (c) 2016 Intel Corporation
-
-# Permission is hereby granted, free of charge, to any person obtaining a copy
-# of this software and associated documentation files (the "Software"), to deal
-# in the Software without restriction, including without limitation the rights
-# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-# copies of the Software, and to permit persons to whom the Software is
-# furnished to do so, subject to the following conditions:
-
-# The above copyright notice and this permission notice shall be included in
-# all copies or substantial portions of the Software.
-
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
-# SOFTWARE.
-
-"""Tests for the monitoring module.
-
-This provides tests for the framework.monitoring modules.
-
-"""
-
-from __future__ import (
- absolute_import, division, print_function, unicode_literals
-)
-
-try:
- from unittest import mock
-except ImportError:
- import mock
-
-import nose.tools as nt
-
-from . import utils
-from framework import monitoring, exceptions
-
-
-class TestMonitoring(object):
- """Tests for Monitoring methods."""
-
- def __init__(self):
- """Setup for TestMonitoring
-
- This create a monitoring.Monitoring instance with monitoring disabled
- to avoid reading the rules in piglit.conf.
-
- """
- self.regex = r'\*ERROR\*|BUG:'
- self.init_contents = r'foo bar\n'
- self.no_error_contents = r'foo bar\n'
- self.error_contents = r'BUG:bar\n'
- self.monitoring = monitoring.Monitoring(False)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_delete_rule(self):
- """monitoring.Monitoring: add and delete rule."""
-
- with utils.nose.tempfile(self.init_contents) as tfile:
- self.monitoring.add_rule('error_file',
- 'file',
- tfile,
- self.regex)
- self.monitoring.update_monitoring()
-
- self.monitoring.delete_rule('error_file')
- with open(tfile, 'w') as fp:
- fp.write(self.error_contents)
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, False)
-
- @nt.raises(exceptions.PiglitFatalError)
- def test_Monitoring_add_rule_bad_format(self):
- """monitoring.Monitoring: add non existing type rule."""
-
- with utils.nose.tempfile(self.init_contents) as tfile:
- self.monitoring.add_rule('error_file_bad_type',
- 'bad_type',
- tfile,
- self.regex)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_file_error(self):
- """monitoring.Monitoring: error found on a file."""
-
- with utils.nose.tempfile(self.init_contents) as tfile:
- self.monitoring.add_rule('error_file',
- 'file',
- tfile,
- self.regex)
- self.monitoring.update_monitoring()
-
- with open(tfile, 'w') as fp:
- fp.write(self.error_contents)
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, True)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_file_no_error(self):
- """monitoring.Monitoring: no error found on a file."""
-
- with utils.nose.tempfile(self.init_contents) as tfile:
- self.monitoring.add_rule('no_error_file',
- 'file',
- tfile,
- self.regex)
- self.monitoring.update_monitoring()
-
- with open(tfile, 'w') as fp:
- fp.write(self.no_error_contents)
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, False)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_locked_file_error(self):
- """monitoring.Monitoring: error found on a locked file."""
-
- with utils.nose.tempfile(self.init_contents) as tfile:
- self.monitoring.add_rule('error_locked_file',
- 'locked_file',
- tfile,
- self.regex)
- self.monitoring.update_monitoring()
-
- with open(tfile, 'w') as fp:
- fp.write(self.error_contents)
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, True)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_locked_file_no_error(self):
- """monitoring.Monitoring: no error found on a locked file."""
-
- with utils.nose.tempfile(self.init_contents) as tfile:
- self.monitoring.add_rule('no_error_file',
- 'locked_file',
- tfile,
- self.regex)
- self.monitoring.update_monitoring()
-
- with open(tfile, 'w') as fp:
- fp.write(self.no_error_contents)
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, False)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_dmesg_error(self):
- """monitoring.Monitoring: error found on the dmesg."""
- mock_out = mock.Mock(return_value=b'[1.0]This\n[2.0]is\n[3.0]dmesg')
- with mock.patch('framework.dmesg.subprocess.check_output', mock_out):
- self.monitoring.add_rule('no_error_file',
- 'dmesg',
- '--level emerg,alert,crit,err',
- self.regex)
- self.monitoring.update_monitoring()
-
- mock_out.return_value = b'[4.0]foo\n[5.0]*ERROR* bar'
- with mock.patch('framework.dmesg.subprocess.check_output', mock_out):
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, True)
-
- @utils.nose.Skip.platform('linux')
- def test_Monitoring_dmesg_no_error(self):
- """monitoring.Monitoring: no error found on the dmesg."""
- mock_out = mock.Mock(return_value=b'[1.0]This\n[2.0]is\n[3.0]dmesg')
- with mock.patch('framework.dmesg.subprocess.check_output', mock_out):
- self.monitoring.add_rule('no_error_file',
- 'dmesg',
- '--level emerg,alert,crit,err',
- self.regex)
- self.monitoring.update_monitoring()
-
- mock_out.return_value = b'[4.0]foo\n[5.0] bar'
- with mock.patch('framework.dmesg.subprocess.check_output', mock_out):
- self.monitoring.check_monitoring()
-
- nt.assert_equal(self.monitoring.abort_needed, False)