mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	* test/: PEP8 compliancy - Make PEP8 compliant * Python3 chokes on casting int to bytes (#24952) But if we tell the formatter that the var is a number, it works
		
			
				
	
	
		
			84 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			3.1 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 json
 | |
| import sys
 | |
| 
 | |
| 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):
 | |
|     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',
 | |
|                 })
 | |
|             )
 |