mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
states.disk: rewrite unit tests
This commit is contained in:
parent
82c77b533f
commit
6cbe31e6c2
1 changed files with 150 additions and 34 deletions
|
@ -1,6 +1,6 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
'''
|
||||
:codeauthor: :email:`Jayesh Kariya <jayeshk@saltstack.com>`
|
||||
Tests for disk state
|
||||
'''
|
||||
# Import Python libs
|
||||
from __future__ import absolute_import
|
||||
|
@ -26,46 +26,162 @@ disk.__salt__ = {}
|
|||
@skipIf(NO_MOCK, NO_MOCK_REASON)
|
||||
class DiskTestCase(TestCase):
|
||||
'''
|
||||
Test cases for salt.states.disk
|
||||
Test disk state
|
||||
'''
|
||||
# 'status' function tests: 1
|
||||
def setUp(self):
|
||||
'''
|
||||
setup common test info
|
||||
'''
|
||||
self.mock_data = {
|
||||
'/': {
|
||||
'1K-blocks': '41147472',
|
||||
'available': '37087976',
|
||||
'capacity': '6%',
|
||||
'filesystem': '/dev/xvda1',
|
||||
'used': '2172880'},
|
||||
'/dev': {
|
||||
'1K-blocks': '10240',
|
||||
'available': '10240',
|
||||
'capacity': '0%',
|
||||
'filesystem': 'udev',
|
||||
'used': '0'},
|
||||
'/run': {
|
||||
'1K-blocks': '410624',
|
||||
'available': '379460',
|
||||
'capacity': '8%',
|
||||
'filesystem': 'tmpfs',
|
||||
'used': '31164'},
|
||||
'/sys/fs/cgroup': {
|
||||
'1K-blocks': '1026556',
|
||||
'available': '1026556',
|
||||
'capacity': '0%',
|
||||
'filesystem': 'tmpfs',
|
||||
'used': '0'}
|
||||
}
|
||||
self.__salt__ = {
|
||||
'disk.usage': MagicMock(return_value=self.mock_data),
|
||||
}
|
||||
|
||||
def test_status_missing(self):
|
||||
'''
|
||||
Test disk.status when name not found
|
||||
'''
|
||||
mock_fs = '/mnt/cheese'
|
||||
mock_ret = {'name': mock_fs,
|
||||
'result': False,
|
||||
'comment': 'Named disk mount not present ',
|
||||
'changes': {},
|
||||
'data': {}}
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
ret = disk.status(mock_fs)
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
def test_status_type_error(self):
|
||||
'''
|
||||
Test disk.status with incorrectly formatted arguments
|
||||
'''
|
||||
mock_fs = '/'
|
||||
mock_ret = {'name': mock_fs,
|
||||
'result': False,
|
||||
'comment': 'maximum must be an integer ',
|
||||
'changes': {},
|
||||
'data': {}}
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
ret = disk.status(mock_fs, maximum=r'e^{i\pi}')
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
mock_ret['comment'] = 'minimum must be an integer '
|
||||
ret = disk.status(mock_fs, minimum=r'\cos\pi + i\sin\pi')
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
def test_status_range_error(self):
|
||||
'''
|
||||
Test disk.status with excessive extrema
|
||||
'''
|
||||
mock_fs = '/'
|
||||
mock_ret = {'name': mock_fs,
|
||||
'result': False,
|
||||
'comment': 'maximum must be in the range [0, 100] ',
|
||||
'changes': {},
|
||||
'data': {}}
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
ret = disk.status(mock_fs, maximum='-1')
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
mock_ret['comment'] = 'minimum must be in the range [0, 100] '
|
||||
ret = disk.status(mock_fs, minimum='101')
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
def test_status_inverted_range(self):
|
||||
'''
|
||||
Test disk.status when minimum > maximum
|
||||
'''
|
||||
mock_fs = '/'
|
||||
mock_ret = {'name': mock_fs,
|
||||
'result': False,
|
||||
'comment': 'Min must be less than max ',
|
||||
'changes': {},
|
||||
'data': {}}
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
ret = disk.status(mock_fs, maximum='0', minimum='1')
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
def test_status_threshold(self):
|
||||
'''
|
||||
Test disk.status when filesystem triggers thresholds
|
||||
'''
|
||||
mock_min = 100
|
||||
mock_max = 0
|
||||
mock_fs = '/'
|
||||
mock_used = int(self.mock_data[mock_fs]['capacity'].strip('%'))
|
||||
mock_ret = {'name': mock_fs,
|
||||
'result': False,
|
||||
'comment': '',
|
||||
'changes': {},
|
||||
'data': self.mock_data[mock_fs]}
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
mock_ret['comment'] = 'Disk used space is below minimum of {0}% at {1}%'.format(
|
||||
mock_min,
|
||||
mock_used
|
||||
)
|
||||
ret = disk.status(mock_fs, minimum=mock_min)
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
mock_ret['comment'] = 'Disk used space is above maximum of {0}% at {1}%'.format(
|
||||
mock_max,
|
||||
mock_used
|
||||
)
|
||||
ret = disk.status(mock_fs, maximum=mock_max)
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
def test_status(self):
|
||||
'''
|
||||
Test to return the current disk usage stats for the named mount point
|
||||
Test disk.status when filesystem meets thresholds
|
||||
'''
|
||||
name = 'mydisk'
|
||||
mock_min = 0
|
||||
mock_max = 100
|
||||
mock_fs = '/'
|
||||
mock_ret = {'name': mock_fs,
|
||||
'result': True,
|
||||
'comment': 'Disk in acceptable range',
|
||||
'changes': {},
|
||||
'data': self.mock_data[mock_fs]}
|
||||
|
||||
ret = {'name': name,
|
||||
'result': False,
|
||||
'comment': '',
|
||||
'changes': {},
|
||||
'data': {}}
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
ret = disk.status(mock_fs, minimum=mock_min)
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
mock = MagicMock(side_effect=[[], [name], {name: {'capacity': '8 %'}},
|
||||
{name: {'capacity': '22 %'}},
|
||||
{name: {'capacity': '15 %'}}])
|
||||
with patch.dict(disk.__salt__, {'disk.usage': mock}):
|
||||
comt = ('Named disk mount not present ')
|
||||
ret.update({'comment': comt})
|
||||
self.assertDictEqual(disk.status(name), ret)
|
||||
|
||||
comt = ('Min must be less than max')
|
||||
ret.update({'comment': comt})
|
||||
self.assertDictEqual(disk.status(name, '10 %', '20 %'), ret)
|
||||
|
||||
comt = ('Disk is below minimum of 10 at 8')
|
||||
ret.update({'comment': comt, 'data': {'capacity': '8 %'}})
|
||||
self.assertDictEqual(disk.status(name, '20 %', '10 %'), ret)
|
||||
|
||||
comt = ('Disk is above maximum of 20 at 22')
|
||||
ret.update({'comment': comt, 'data': {'capacity': '22 %'}})
|
||||
self.assertDictEqual(disk.status(name, '20 %', '10 %'), ret)
|
||||
|
||||
comt = ('Disk in acceptable range')
|
||||
ret.update({'comment': comt, 'result': True,
|
||||
'data': {'capacity': '15 %'}})
|
||||
self.assertDictEqual(disk.status(name, '20 %', '10 %'), ret)
|
||||
with patch.dict(disk.__salt__, self.__salt__):
|
||||
ret = disk.status(mock_fs, maximum=mock_max)
|
||||
self.assertEqual(ret, mock_ret)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
|
Loading…
Add table
Reference in a new issue