2013-11-27 11:19:24 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
2012-05-14 17:18:36 +00:00
|
|
|
'''
|
|
|
|
Tests for the file state
|
|
|
|
'''
|
2013-06-27 12:32:54 +00:00
|
|
|
# Import python libs
|
2014-11-21 19:05:13 +00:00
|
|
|
from __future__ import absolute_import
|
2016-08-10 20:04:56 +00:00
|
|
|
import errno
|
2015-04-07 02:31:13 +00:00
|
|
|
import os
|
|
|
|
import textwrap
|
2012-06-30 22:48:28 +00:00
|
|
|
import tempfile
|
2012-05-14 17:18:36 +00:00
|
|
|
|
2013-06-27 12:32:54 +00:00
|
|
|
# Import Salt Testing libs
|
2017-04-03 16:04:09 +00:00
|
|
|
from tests.support.case import ModuleCase
|
2017-03-07 12:49:17 +00:00
|
|
|
from tests.support.paths import TMP_STATE_TREE
|
2017-04-02 16:09:47 +00:00
|
|
|
from tests.support.mixins import SaltReturnAssertsMixin
|
|
|
|
|
2013-06-24 19:06:49 +00:00
|
|
|
# Import salt libs
|
2015-04-07 02:31:13 +00:00
|
|
|
import salt.utils
|
|
|
|
|
2016-08-03 18:24:55 +00:00
|
|
|
IS_WINDOWS = salt.utils.is_windows()
|
2013-06-24 19:06:49 +00:00
|
|
|
|
2012-05-29 16:40:20 +00:00
|
|
|
|
2017-04-03 16:04:09 +00:00
|
|
|
class CMDTest(ModuleCase, SaltReturnAssertsMixin):
|
2012-05-14 17:18:36 +00:00
|
|
|
'''
|
|
|
|
Validate the cmd state
|
|
|
|
'''
|
2015-04-07 02:31:13 +00:00
|
|
|
def test_run_simple(self):
|
2012-05-14 17:18:36 +00:00
|
|
|
'''
|
|
|
|
cmd.run
|
|
|
|
'''
|
2016-08-03 18:24:55 +00:00
|
|
|
cmd = 'dir' if IS_WINDOWS else 'ls'
|
|
|
|
ret = self.run_state('cmd.run', name=cmd, cwd=tempfile.gettempdir())
|
2012-11-21 12:43:53 +00:00
|
|
|
self.assertSaltTrueReturn(ret)
|
2012-05-14 17:18:36 +00:00
|
|
|
|
2015-04-07 02:31:13 +00:00
|
|
|
def test_test_run_simple(self):
|
2012-05-14 17:18:36 +00:00
|
|
|
'''
|
|
|
|
cmd.run test interface
|
|
|
|
'''
|
2012-06-30 22:48:28 +00:00
|
|
|
ret = self.run_state('cmd.run', name='ls',
|
|
|
|
cwd=tempfile.gettempdir(), test=True)
|
2012-11-21 12:43:53 +00:00
|
|
|
self.assertSaltNoneReturn(ret)
|
2012-07-20 06:21:01 +00:00
|
|
|
|
2016-05-09 17:06:44 +00:00
|
|
|
|
2017-04-03 16:04:09 +00:00
|
|
|
class CMDRunRedirectTest(ModuleCase, SaltReturnAssertsMixin):
|
2016-05-09 17:06:44 +00:00
|
|
|
'''
|
|
|
|
Validate the cmd state of run_redirect
|
|
|
|
'''
|
|
|
|
def setUp(self):
|
|
|
|
self.state_name = 'run_redirect'
|
|
|
|
state_filename = self.state_name + '.sls'
|
2017-03-07 12:49:17 +00:00
|
|
|
self.state_file = os.path.join(TMP_STATE_TREE, state_filename)
|
2016-05-09 17:06:44 +00:00
|
|
|
|
2016-08-10 22:09:38 +00:00
|
|
|
# Create the testfile and release the handle
|
2017-03-07 12:49:17 +00:00
|
|
|
fd, self.test_file = tempfile.mkstemp()
|
2016-08-10 20:04:56 +00:00
|
|
|
try:
|
2017-03-07 12:49:17 +00:00
|
|
|
os.close(fd)
|
|
|
|
except OSError as exc:
|
|
|
|
if exc.errno != errno.EBADF:
|
|
|
|
raise exc
|
|
|
|
|
|
|
|
# Create the testfile and release the handle
|
|
|
|
fd, self.test_tmp_path = tempfile.mkstemp()
|
|
|
|
try:
|
|
|
|
os.close(fd)
|
2016-08-10 20:04:56 +00:00
|
|
|
except OSError as exc:
|
|
|
|
if exc.errno != errno.EBADF:
|
|
|
|
raise exc
|
2016-08-10 22:09:38 +00:00
|
|
|
|
2016-05-09 17:06:44 +00:00
|
|
|
super(CMDRunRedirectTest, self).setUp()
|
|
|
|
|
|
|
|
def tearDown(self):
|
2017-03-07 12:49:17 +00:00
|
|
|
for path in (self.state_file, self.test_tmp_path, self.test_file):
|
|
|
|
try:
|
|
|
|
os.remove(path)
|
|
|
|
except OSError:
|
|
|
|
# Not all of the tests leave files around that we want to remove
|
|
|
|
# As some of the tests create the sls files in the test itself,
|
|
|
|
# And some are using files in the integration test file state tree.
|
|
|
|
pass
|
2016-05-09 17:06:44 +00:00
|
|
|
super(CMDRunRedirectTest, self).tearDown()
|
2015-04-07 02:31:13 +00:00
|
|
|
|
|
|
|
def test_run_unless(self):
|
|
|
|
'''
|
|
|
|
test cmd.run unless
|
|
|
|
'''
|
2017-03-07 12:49:17 +00:00
|
|
|
state_key = 'cmd_|-{0}_|-{0}_|-run'.format(self.test_tmp_path)
|
2016-08-10 22:09:38 +00:00
|
|
|
with salt.utils.fopen(self.state_file, 'w') as fb_:
|
|
|
|
fb_.write(textwrap.dedent('''
|
2017-03-07 12:49:17 +00:00
|
|
|
{0}:
|
2016-08-10 22:09:38 +00:00
|
|
|
cmd.run:
|
2017-03-07 12:49:17 +00:00
|
|
|
- unless: echo cheese > {1}
|
|
|
|
'''.format(self.test_tmp_path, self.test_file)))
|
2016-05-09 17:06:44 +00:00
|
|
|
|
|
|
|
ret = self.run_function('state.sls', [self.state_name])
|
|
|
|
self.assertTrue(ret[state_key]['result'])
|
2015-04-07 02:31:13 +00:00
|
|
|
|
2016-08-18 17:01:32 +00:00
|
|
|
def test_run_unless_multiple_cmds(self):
|
|
|
|
'''
|
|
|
|
test cmd.run using multiple unless options where the first cmd in the
|
|
|
|
list will pass, but the second will fail. This tests the fix for issue
|
|
|
|
#35384. (The fix is in PR #35545.)
|
|
|
|
'''
|
|
|
|
sls = self.run_function('state.sls', mods='issue-35384')
|
|
|
|
self.assertSaltTrueReturn(sls)
|
|
|
|
# We must assert against the comment here to make sure the comment reads that the
|
|
|
|
# command "echo "hello"" was run. This ensures that we made it to the last unless
|
|
|
|
# command in the state. If the comment reads "unless execution succeeded", or similar,
|
|
|
|
# then the unless state run bailed out after the first unless command succeeded,
|
|
|
|
# which is the bug we're regression testing for.
|
|
|
|
self.assertEqual(sls['cmd_|-cmd_run_unless_multiple_|-echo "hello"_|-run']['comment'],
|
|
|
|
'Command "echo "hello"" run')
|
|
|
|
|
2015-04-07 02:31:13 +00:00
|
|
|
def test_run_creates_exists(self):
|
|
|
|
'''
|
|
|
|
test cmd.run creates already there
|
|
|
|
'''
|
2016-08-10 22:09:38 +00:00
|
|
|
state_key = 'cmd_|-echo >> {0}_|-echo >> {0}_|-run'.format(self.test_file)
|
|
|
|
with salt.utils.fopen(self.state_file, 'w') as fb_:
|
|
|
|
fb_.write(textwrap.dedent('''
|
|
|
|
echo >> {0}:
|
|
|
|
cmd.run:
|
|
|
|
- creates: {0}
|
|
|
|
'''.format(self.test_file)))
|
2016-05-09 17:06:44 +00:00
|
|
|
|
|
|
|
ret = self.run_function('state.sls', [self.state_name])
|
|
|
|
self.assertTrue(ret[state_key]['result'])
|
|
|
|
self.assertEqual(len(ret[state_key]['changes']), 0)
|
2015-04-07 02:31:13 +00:00
|
|
|
|
|
|
|
def test_run_creates_new(self):
|
|
|
|
'''
|
|
|
|
test cmd.run creates not there
|
|
|
|
'''
|
2016-05-09 17:06:44 +00:00
|
|
|
os.remove(self.test_file)
|
2016-08-10 22:09:38 +00:00
|
|
|
state_key = 'cmd_|-echo >> {0}_|-echo >> {0}_|-run'.format(self.test_file)
|
|
|
|
with salt.utils.fopen(self.state_file, 'w') as fb_:
|
|
|
|
fb_.write(textwrap.dedent('''
|
|
|
|
echo >> {0}:
|
|
|
|
cmd.run:
|
|
|
|
- creates: {0}
|
|
|
|
'''.format(self.test_file)))
|
2016-05-09 17:06:44 +00:00
|
|
|
|
|
|
|
ret = self.run_function('state.sls', [self.state_name])
|
|
|
|
self.assertTrue(ret[state_key]['result'])
|
|
|
|
self.assertEqual(len(ret[state_key]['changes']), 4)
|
|
|
|
|
|
|
|
def test_run_redirect(self):
|
|
|
|
'''
|
|
|
|
test cmd.run with shell redirect
|
|
|
|
'''
|
2016-08-10 22:09:38 +00:00
|
|
|
state_key = 'cmd_|-echo test > {0}_|-echo test > {0}_|-run'.format(self.test_file)
|
|
|
|
with salt.utils.fopen(self.state_file, 'w') as fb_:
|
|
|
|
fb_.write(textwrap.dedent('''
|
|
|
|
echo test > {0}:
|
|
|
|
cmd.run
|
|
|
|
'''.format(self.test_file)))
|
2016-05-09 17:06:44 +00:00
|
|
|
|
|
|
|
ret = self.run_function('state.sls', [self.state_name])
|
|
|
|
self.assertTrue(ret[state_key]['result'])
|
|
|
|
|
|
|
|
|
2017-04-03 16:04:09 +00:00
|
|
|
class CMDRunWatchTest(ModuleCase, SaltReturnAssertsMixin):
|
2016-05-09 17:06:44 +00:00
|
|
|
'''
|
|
|
|
Validate the cmd state of run_watch
|
|
|
|
'''
|
|
|
|
def setUp(self):
|
|
|
|
self.state_name = 'run_watch'
|
|
|
|
state_filename = self.state_name + '.sls'
|
2017-03-07 12:49:17 +00:00
|
|
|
self.state_file = os.path.join(TMP_STATE_TREE, state_filename)
|
2016-05-09 17:06:44 +00:00
|
|
|
super(CMDRunWatchTest, self).setUp()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
os.remove(self.state_file)
|
|
|
|
super(CMDRunWatchTest, self).tearDown()
|
2015-04-07 02:31:13 +00:00
|
|
|
|
|
|
|
def test_run_watch(self):
|
|
|
|
'''
|
|
|
|
test cmd.run watch
|
|
|
|
'''
|
2016-08-10 22:09:38 +00:00
|
|
|
saltines_key = 'cmd_|-saltines_|-echo changed=true_|-run'
|
|
|
|
biscuits_key = 'cmd_|-biscuits_|-echo biscuits_|-wait'
|
|
|
|
|
|
|
|
with salt.utils.fopen(self.state_file, 'w') as fb_:
|
|
|
|
fb_.write(textwrap.dedent('''
|
|
|
|
saltines:
|
|
|
|
cmd.run:
|
|
|
|
- name: echo changed=true
|
|
|
|
- cwd: /
|
|
|
|
- stateful: True
|
|
|
|
|
|
|
|
biscuits:
|
|
|
|
cmd.wait:
|
|
|
|
- name: echo biscuits
|
|
|
|
- cwd: /
|
|
|
|
- watch:
|
|
|
|
- cmd: saltines
|
|
|
|
'''))
|
2016-05-09 17:06:44 +00:00
|
|
|
|
|
|
|
ret = self.run_function('state.sls', [self.state_name])
|
|
|
|
self.assertTrue(ret[saltines_key]['result'])
|
|
|
|
self.assertTrue(ret[biscuits_key]['result'])
|