mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
Merge pull request #23850 from jayeshka/sysbench-unit-test
adding sysbench unit test case
This commit is contained in:
commit
ce60582de4
1 changed files with 127 additions and 0 deletions
127
tests/unit/modules/sysbench_test.py
Normal file
127
tests/unit/modules/sysbench_test.py
Normal file
|
@ -0,0 +1,127 @@
|
|||
# -*- 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.modules import sysbench
|
||||
|
||||
# Globals
|
||||
sysbench.__salt__ = {}
|
||||
|
||||
|
||||
@skipIf(NO_MOCK, NO_MOCK_REASON)
|
||||
class SysbenchTestCase(TestCase):
|
||||
'''
|
||||
Test cases to salt.modules.sysbench
|
||||
'''
|
||||
def test_cpu(self):
|
||||
'''
|
||||
Test to tests to the CPU performance of minions.
|
||||
'''
|
||||
with patch.dict(sysbench.__salt__,
|
||||
{'cmd.run': MagicMock(return_value={'A': 'a'})}):
|
||||
with patch.object(sysbench, '_parser', return_value={'A': 'a'}):
|
||||
self.assertEqual(sysbench.cpu(),
|
||||
{'Prime numbers limit: 500':
|
||||
{'A': 'a'}, 'Prime numbers limit: 5000':
|
||||
{'A': 'a'}, 'Prime numbers limit: 2500':
|
||||
{'A': 'a'}, 'Prime numbers limit: 1000':
|
||||
{'A': 'a'}})
|
||||
|
||||
def test_threads(self):
|
||||
'''
|
||||
Test to this tests the performance of the processor's scheduler
|
||||
'''
|
||||
with patch.dict(sysbench.__salt__,
|
||||
{'cmd.run': MagicMock(return_value={'A': 'a'})}):
|
||||
with patch.object(sysbench, '_parser', return_value={'A': 'a'}):
|
||||
self.assertEqual(sysbench.threads(),
|
||||
{'Yields: 500 Locks: 8': {'A': 'a'},
|
||||
'Yields: 200 Locks: 4': {'A': 'a'},
|
||||
'Yields: 1000 Locks: 16': {'A': 'a'},
|
||||
'Yields: 100 Locks: 2': {'A': 'a'}})
|
||||
|
||||
def test_mutex(self):
|
||||
'''
|
||||
Test to tests the implementation of mutex
|
||||
'''
|
||||
with patch.dict(sysbench.__salt__,
|
||||
{'cmd.run': MagicMock(return_value={'A': 'a'})}):
|
||||
with patch.object(sysbench, '_parser', return_value={'A': 'a'}):
|
||||
self.assertEqual(sysbench.mutex(),
|
||||
{'Mutex: 1000 Locks: 25000 Loops: 10000':
|
||||
{'A': 'a'},
|
||||
'Mutex: 50 Locks: 10000 Loops: 2500':
|
||||
{'A': 'a'},
|
||||
'Mutex: 1000 Locks: 10000 Loops: 5000':
|
||||
{'A': 'a'},
|
||||
'Mutex: 500 Locks: 50000 Loops: 5000':
|
||||
{'A': 'a'},
|
||||
'Mutex: 500 Locks: 25000 Loops: 2500':
|
||||
{'A': 'a'},
|
||||
'Mutex: 500 Locks: 10000 Loops: 10000':
|
||||
{'A': 'a'},
|
||||
'Mutex: 50 Locks: 50000 Loops: 10000':
|
||||
{'A': 'a'},
|
||||
'Mutex: 1000 Locks: 50000 Loops: 2500':
|
||||
{'A': 'a'},
|
||||
'Mutex: 50 Locks: 25000 Loops: 5000':
|
||||
{'A': 'a'}})
|
||||
|
||||
def test_memory(self):
|
||||
'''
|
||||
Test to this tests the memory for read and write operations.
|
||||
'''
|
||||
with patch.dict(sysbench.__salt__,
|
||||
{'cmd.run': MagicMock(return_value={'A': 'a'})}):
|
||||
with patch.object(sysbench, '_parser', return_value={'A': 'a'}):
|
||||
self.assertEqual(sysbench.memory(),
|
||||
{'Operation: read Scope: local':
|
||||
{'A': 'a'},
|
||||
'Operation: write Scope: local':
|
||||
{'A': 'a'},
|
||||
'Operation: read Scope: global':
|
||||
{'A': 'a'},
|
||||
'Operation: write Scope: global':
|
||||
{'A': 'a'}})
|
||||
|
||||
def test_fileio(self):
|
||||
'''
|
||||
Test to this tests for the file read and write operations
|
||||
'''
|
||||
with patch.dict(sysbench.__salt__,
|
||||
{'cmd.run': MagicMock(return_value={'A': 'a'})}):
|
||||
with patch.object(sysbench, '_parser', return_value={'A': 'a'}):
|
||||
self.assertEqual(sysbench.fileio(),
|
||||
{'Mode: seqrd': {'A': 'a'},
|
||||
'Mode: seqwr': {'A': 'a'},
|
||||
'Mode: rndrd': {'A': 'a'},
|
||||
'Mode: rndwr': {'A': 'a'},
|
||||
'Mode: seqrewr': {'A': 'a'},
|
||||
'Mode: rndrw': {'A': 'a'}})
|
||||
|
||||
def test_ping(self):
|
||||
'''
|
||||
Test to ping
|
||||
'''
|
||||
self.assertTrue(sysbench.ping())
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
from integration import run_tests
|
||||
run_tests(SysbenchTestCase, needs_daemon=False)
|
Loading…
Add table
Reference in a new issue