mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			86 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| # (c) 2016, James Cammarata <jimi@sngx.net>
 | |
| #
 | |
| # This file is part of Ansible
 | |
| #
 | |
| # Ansible is free software: you can redistribute it and/or modify
 | |
| # it under the terms of the GNU General Public License as published by
 | |
| # the Free Software Foundation, either version 3 of the License, or
 | |
| # (at your option) any later version.
 | |
| #
 | |
| # Ansible is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with Ansible.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| # Make coding more python3-ish
 | |
| from __future__ import (absolute_import, division)
 | |
| __metaclass__ = type
 | |
| 
 | |
| import sys
 | |
| import json
 | |
| 
 | |
| from units.mock.procenv import swap_stdin_and_argv
 | |
| 
 | |
| from ansible.compat.tests import unittest
 | |
| from ansible.compat.tests.mock import MagicMock
 | |
| 
 | |
| 
 | |
| class TestModuleUtilsBasic(unittest.TestCase):
 | |
|     @unittest.skipIf(sys.version_info[0] >= 3, "Python 3 is not supported on targets (yet)")
 | |
|     def test_module_utils_basic__log_invocation(self):
 | |
|         with swap_stdin_and_argv(stdin_data=json.dumps(
 | |
|             dict(
 | |
|                 ANSIBLE_MODULE_ARGS=dict(
 | |
|                     foo=False, bar=[1,2,3], bam="bam", baz=u'baz'),
 | |
|                 ))):
 | |
|             from ansible.module_utils import basic
 | |
| 
 | |
|             # test basic log invocation
 | |
|             basic._ANSIBLE_ARGS = None
 | |
|             am = basic.AnsibleModule(
 | |
|                 argument_spec=dict(
 | |
|                     foo = dict(default=True, type='bool'),
 | |
|                     bar = dict(default=[], type='list'),
 | |
|                     bam = dict(default="bam"),
 | |
|                     baz = dict(default=u"baz"),
 | |
|                     password = dict(default=True),
 | |
|                     no_log = dict(default="you shouldn't see me", no_log=True),
 | |
|                 ),
 | |
|             )
 | |
| 
 | |
|             am.log = MagicMock()
 | |
|             am._log_invocation()
 | |
| 
 | |
|             # Message is generated from a dict so it will be in an unknown order.
 | |
|             # have to check this manually rather than with assert_called_with()
 | |
|             args = am.log.call_args[0]
 | |
|             self.assertEqual(len(args), 1)
 | |
|             message = args[0]
 | |
| 
 | |
|             self.assertEqual(
 | |
|                 len(message),
 | |
|                 len('Invoked with bam=bam bar=[1, 2, 3] foo=False baz=baz no_log=NOT_LOGGING_PARAMETER password=NOT_LOGGING_PASSWORD')
 | |
|             )
 | |
|             self.assertTrue(message.startswith('Invoked with '))
 | |
|             self.assertIn(' bam=bam', message)
 | |
|             self.assertIn(' bar=[1, 2, 3]', message)
 | |
|             self.assertIn(' foo=False', message)
 | |
|             self.assertIn(' baz=baz', message)
 | |
|             self.assertIn(' no_log=NOT_LOGGING_PARAMETER', message)
 | |
|             self.assertIn(' password=NOT_LOGGING_PASSWORD', message)
 | |
| 
 | |
|             kwargs = am.log.call_args[1]
 | |
|             self.assertEqual(kwargs,
 | |
|                     dict(log_args={
 | |
|                         'foo': 'False',
 | |
|                         'bar': '[1, 2, 3]',
 | |
|                         'bam': 'bam',
 | |
|                         'baz': 'baz',
 | |
|                         'password': 'NOT_LOGGING_PASSWORD',
 | |
|                         'no_log': 'NOT_LOGGING_PARAMETER',
 | |
|                     })
 | |
|                 )
 |