Skip to content

Commit

Permalink
Merge pull request #43 from trobert2/modiffied_heat_tests
Browse files Browse the repository at this point in the history
Modified test for heat handler plugin
  • Loading branch information
alexpilotti committed Feb 9, 2014
2 parents dfbf133 + b980398 commit 9ef84f6
Showing 1 changed file with 21 additions and 6 deletions.
27 changes: 21 additions & 6 deletions cloudbaseinit/tests/plugins/windows/userdataplugins/test_heat.py
Expand Up @@ -28,22 +28,37 @@ class HeatUserDataHandlerTests(unittest.TestCase):
def setUp(self):
self._heat = heat.HeatPlugin()

@mock.patch('os.path.exists')
@mock.patch('os.makedirs')
def test_check_heat_config_dir(self, mock_makedirs, mock_exists):
mock_exists.return_value = False
self._heat._check_heat_config_dir()
mock_exists.assert_called_once_with(CONF.heat_config_dir)
mock_makedirs.assert_called_once_with(CONF.heat_config_dir)

@mock.patch('cloudbaseinit.plugins.windows.userdatautils'
'.execute_user_data_script')
def _test_process(self, mock_execute_user_data_script, filename):
@mock.patch('cloudbaseinit.plugins.windows.userdataplugins.heat'
'.HeatPlugin._check_heat_config_dir')
def _test_process(self, mock_check_heat_config_dir,
mock_execute_user_data_script, filename):
mock_part = mock.MagicMock()
mock_part.get_filename.return_value = filename
response = self._heat.process(mock_part)
with mock.patch('__builtin__.open', mock.mock_open(),
create=True) as handle:
response = self._heat.process(mock_part)
handle().write.assert_called_once_with(mock_part.get_payload())
mock_check_heat_config_dir.assert_called_once_with()
mock_part.get_filename.assert_called_with()
if filename:
if filename == self._heat._heat_user_data_filename:
mock_execute_user_data_script.assert_called_with(
mock_part.get_payload())
self.assertEqual(response, mock_execute_user_data_script())
else:
self.assertTrue(response is None)

def test_process(self):
self._test_process(filename='cfn-userdata')
self._test_process(filename=self._heat._heat_user_data_filename)

def test_process_content_not_supported(self):
self._test_process(filename=None)
def test_process_content_other_data(self):
self._test_process(filename='other data')

0 comments on commit 9ef84f6

Please sign in to comment.