salt/tests/integration/modules/cmdmod.py

198 lines
6.0 KiB
Python
Raw Normal View History

2012-03-27 23:05:38 +00:00
import os
import integration
2013-03-03 06:55:19 +00:00
import tempfile
import sys
2013-03-03 06:55:19 +00:00
from saltunittest import skipIf
try:
from mock import Mock, patch
has_mock = True
except ImportError:
has_mock = False
patch = lambda x: lambda y: None
2012-03-27 23:05:38 +00:00
@skipIf(has_mock is False, "mock python module is unavailable")
2012-03-27 23:05:38 +00:00
class CMDModuleTest(integration.ModuleCase):
'''
Validate the cmd module
'''
def test_run(self):
'''
cmd.run
'''
shell = os.environ['SHELL']
2012-03-27 23:05:38 +00:00
self.assertTrue(self.run_function('cmd.run', ['echo $SHELL']))
self.assertEqual(
2013-03-21 22:22:29 +00:00
self.run_function('cmd.run',
['echo $SHELL',
'shell={0}'.format(shell)]).rstrip(),
shell)
2012-03-27 23:05:38 +00:00
@patch('pwd.getpwnam')
@patch('subprocess.Popen')
@patch('json.loads')
def test_os_environment_remains_intact(self, *mocks):
2013-03-03 06:55:19 +00:00
'''
2013-03-21 22:22:29 +00:00
Make sure the OS environment is not tainted after running a command
that specifies runas.
2013-03-03 06:55:19 +00:00
'''
environment = os.environ.copy()
2013-03-21 22:22:29 +00:00
loads_mock, popen_mock, getpwnam_mock = mocks
2013-03-03 06:55:19 +00:00
popen_mock.return_value = Mock(
communicate=lambda *args, **kwags: ['{}', None],
pid=lambda: 1,
retcode=0
)
2013-03-03 06:55:19 +00:00
loads_mock.return_value = {'data': {'USER': 'foo'}}
2013-03-03 06:55:19 +00:00
from salt.modules import cmdmod
2013-03-21 22:22:29 +00:00
cmdmod.__grains__ = {'os': 'darwin'}
if sys.platform.startswith('freebsd'):
shell = '/bin/sh'
else:
shell = '/bin/bash'
2013-03-21 22:22:29 +00:00
try:
cmdmod._run('ls',
cwd=tempfile.gettempdir(),
runas='foobar',
shell=shell)
2013-03-21 22:15:26 +00:00
2013-03-21 22:22:29 +00:00
environment2 = os.environ.copy()
2013-03-21 22:15:26 +00:00
2013-03-21 22:22:29 +00:00
self.assertEquals(environment, environment2)
2013-03-21 22:15:26 +00:00
2013-03-21 22:22:29 +00:00
getpwnam_mock.assert_called_with('foobar')
loads_mock.assert_called_with('{}')
2013-03-21 22:22:29 +00:00
finally:
delattr(cmdmod, '__grains__')
2013-03-03 06:55:19 +00:00
2012-03-27 23:05:38 +00:00
def test_stdout(self):
'''
cmd.run_stdout
'''
2013-03-21 22:22:29 +00:00
self.assertEqual(self.run_function('cmd.run_stdout',
['echo "cheese"']).rstrip(),
'cheese')
2012-03-27 23:05:38 +00:00
def test_stderr(self):
'''
cmd.run_stderr
'''
if sys.platform.startswith('freebsd'):
shell = '/bin/sh'
else:
shell = '/bin/bash'
2013-03-21 22:22:29 +00:00
self.assertEqual(self.run_function('cmd.run_stderr',
['echo "cheese" 1>&2',
'shell={0}'.format(shell)]
).rstrip(),
2013-03-21 22:22:29 +00:00
'cheese')
2012-03-27 23:05:38 +00:00
def test_run_all(self):
'''
cmd.run_all
'''
2012-06-04 22:40:34 +00:00
from salt._compat import string_types
if sys.platform.startswith('freebsd'):
shell = '/bin/sh'
else:
shell = '/bin/bash'
ret = self.run_function('cmd.run_all', ['echo "cheese" 1>&2',
'shell={0}'.format(shell)])
2012-03-27 23:05:38 +00:00
self.assertTrue('pid' in ret)
self.assertTrue('retcode' in ret)
self.assertTrue('stdout' in ret)
self.assertTrue('stderr' in ret)
self.assertTrue(isinstance(ret.get('pid'), int))
self.assertTrue(isinstance(ret.get('retcode'), int))
2012-06-04 22:40:34 +00:00
self.assertTrue(isinstance(ret.get('stdout'), string_types))
self.assertTrue(isinstance(ret.get('stderr'), string_types))
self.assertEqual(ret.get('stderr').rstrip(), 'cheese')
2012-03-27 23:05:38 +00:00
def test_retcode(self):
'''
cmd.retcode
'''
2013-06-19 05:51:44 +00:00
self.assertEqual(self.run_function('cmd.retcode', ['exit 0']), 0)
self.assertEqual(self.run_function('cmd.retcode', ['exit 1']), 1)
2012-03-27 23:05:38 +00:00
def test_which(self):
'''
cmd.which
'''
2013-03-21 22:22:29 +00:00
self.assertEqual(self.run_function('cmd.which', ['cat']).rstrip(),
self.run_function('cmd.run', ['which cat']).rstrip())
2012-03-27 23:05:38 +00:00
def test_has_exec(self):
'''
cmd.has_exec
'''
self.assertTrue(self.run_function('cmd.has_exec', ['python']))
2013-03-21 22:22:29 +00:00
self.assertFalse(self.run_function('cmd.has_exec',
['alllfsdfnwieulrrh9123857ygf']))
2012-03-27 23:05:38 +00:00
def test_exec_code(self):
'''
cmd.exec_code
'''
code = '''
import sys
sys.stdout.write('cheese')
'''
2013-03-21 22:22:29 +00:00
self.assertEqual(self.run_function('cmd.exec_code',
['python', code]).rstrip(),
'cheese')
def test_quotes(self):
'''
cmd.run with quoted command
'''
cmd = '''echo 'SELECT * FROM foo WHERE bar="baz"' '''
expected_result = 'SELECT * FROM foo WHERE bar="baz"'
result = self.run_function('cmd.run_stdout', [cmd]).strip()
self.assertEqual(result, expected_result)
2013-04-30 17:32:21 +00:00
@skipIf(os.geteuid() != 0, 'you must be root to run this test')
def test_quotes_runas(self):
'''
cmd.run with quoted command
'''
cmd = '''echo 'SELECT * FROM foo WHERE bar="baz"' '''
expected_result = 'SELECT * FROM foo WHERE bar="baz"'
try:
2013-03-21 22:22:29 +00:00
runas = os.getlogin()
except:
# On some distros (notably Gentoo) os.getlogin() fails
import pwd
2013-03-21 22:22:29 +00:00
runas = pwd.getpwuid(os.getuid())[0]
result = self.run_function('cmd.run_stdout', [cmd],
runas=runas).strip()
self.assertEqual(result, expected_result)
def test_timeout(self):
'''
cmd.run trigger timeout
'''
self.assertTrue('Timed out' in self.run_function('cmd.run', ['sleep 2 && echo hello', 'timeout=1']))
def test_timeout_success(self):
'''
cmd.run sufficient timeout to succeed
'''
self.assertTrue('hello' == self.run_function('cmd.run', ['sleep 1 && echo hello', 'timeout=2']))
if __name__ == '__main__':
from integration import run_tests
run_tests(CMDModuleTest)