mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
adding states/status unit test case.
This commit is contained in:
parent
c32aae96aa
commit
baec650674
1 changed files with 99 additions and 0 deletions
99
tests/unit/states/status_test.py
Normal file
99
tests/unit/states/status_test.py
Normal file
|
@ -0,0 +1,99 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
'''
|
||||
:codeauthor: :email:`Jayesh Kariya <jayeshk@saltstack.com>`
|
||||
'''
|
||||
# Import Python libs
|
||||
from __future__ import absolute_import
|
||||
|
||||
# Import Salt Testing Libs
|
||||
from salttesting import skipIf, TestCase
|
||||
from salttesting.mock import (
|
||||
NO_MOCK,
|
||||
NO_MOCK_REASON,
|
||||
MagicMock,
|
||||
patch
|
||||
)
|
||||
|
||||
from salttesting.helpers import ensure_in_syspath
|
||||
|
||||
ensure_in_syspath('../../')
|
||||
|
||||
# Import Salt Libs
|
||||
from salt.states import status
|
||||
|
||||
status.__salt__ = {}
|
||||
|
||||
|
||||
@skipIf(NO_MOCK, NO_MOCK_REASON)
|
||||
class StatusTestCase(TestCase):
|
||||
'''
|
||||
Test cases for salt.states.status
|
||||
'''
|
||||
# 'loadavg' function tests: 1
|
||||
|
||||
def test_loadavg(self):
|
||||
'''
|
||||
Test to return the current load average for the specified minion.
|
||||
'''
|
||||
name = 'mymonitor'
|
||||
|
||||
ret = {'name': name,
|
||||
'changes': {},
|
||||
'result': True,
|
||||
'data': {},
|
||||
'comment': ''}
|
||||
|
||||
mock = MagicMock(return_value=[])
|
||||
with patch.dict(status.__salt__, {'status.loadavg': mock}):
|
||||
comt = ('Requested load average mymonitor not available ')
|
||||
ret.update({'comment': comt, 'result': False})
|
||||
self.assertDictEqual(status.loadavg(name), ret)
|
||||
|
||||
mock = MagicMock(return_value={name: 3})
|
||||
with patch.dict(status.__salt__, {'status.loadavg': mock}):
|
||||
comt = ('Min must be less than max')
|
||||
ret.update({'comment': comt, 'result': False})
|
||||
self.assertDictEqual(status.loadavg(name, 1, 5), ret)
|
||||
|
||||
comt = ('Load avg is below minimum of 4 at 3.0')
|
||||
ret.update({'comment': comt, 'data': 3})
|
||||
self.assertDictEqual(status.loadavg(name, 5, 4), ret)
|
||||
|
||||
comt = ('Load avg above maximum of 2 at 3.0')
|
||||
ret.update({'comment': comt, 'data': 3})
|
||||
self.assertDictEqual(status.loadavg(name, 2, 1), ret)
|
||||
|
||||
comt = ('Load avg in acceptable range')
|
||||
ret.update({'comment': comt, 'result': True})
|
||||
self.assertDictEqual(status.loadavg(name, 3, 1), ret)
|
||||
|
||||
# 'process' function tests: 1
|
||||
|
||||
def test_process(self):
|
||||
'''
|
||||
Test to return whether the specified signature
|
||||
is found in the process tree.
|
||||
'''
|
||||
name = 'mymonitor'
|
||||
|
||||
ret = {'name': name,
|
||||
'changes': {},
|
||||
'result': True,
|
||||
'data': {},
|
||||
'comment': ''}
|
||||
|
||||
mock = MagicMock(side_effect=[{}, {name: 1}])
|
||||
with patch.dict(status.__salt__, {'status.pid': mock}):
|
||||
comt = ('Process signature "mymonitor" not found ')
|
||||
ret.update({'comment': comt, 'result': False})
|
||||
self.assertDictEqual(status.process(name), ret)
|
||||
|
||||
comt = ('Process signature "mymonitor" was found ')
|
||||
ret.update({'comment': comt, 'result': True,
|
||||
'data': {name: 1}})
|
||||
self.assertDictEqual(status.process(name), ret)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
from integration import run_tests
|
||||
run_tests(StatusTestCase, needs_daemon=False)
|
Loading…
Add table
Reference in a new issue