mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	* Porting tests to pytest
* Achievement Get: No longer need mock/generator.py
  * Now done via pytest's parametrization
  * Port safe_eval to pytest
  * Port text tests to pytest
  * Port test_set_mode_if_different to pytest
* Change conftest AnsibleModule fixtures to be more flexible
  * Move the AnsibleModules fixtures to module_utils/conftest.py for sharing
  * Testing the argspec code requires:
    * injecting both the argspec and the arguments.
    * Patching the arguments into sys.stdin at a different level
* More porting to obsolete mock/procenv.py
  * Port run_command to pytest
  * Port known_hosts tests to pytest
  * Port safe_eval to pytest
  * Port test_distribution_version.py to pytest
  * Port test_log to pytest
  * Port test__log_invocation to pytest
  * Remove unneeded import of procenv in test_postgresql
* Port test_pip to pytest style
  * As part of this, create a pytest ansiblemodule fixture in
    modules/conftest.py.  This is slightly different than the
    approach taken in module_utils because here we need to override the
    AnsibleModule that the modules will inherit from instead of one that
    we're instantiating ourselves.
* Fixup usage of parametrization in test_deprecate_warn
* Check that the pip module failed in our test
		
	
			
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| #
 | |
| # Copyright (c) 2017 Ansible Project
 | |
| # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| 
 | |
| import json
 | |
| import sys
 | |
| from collections import MutableMapping
 | |
| from io import BytesIO
 | |
| 
 | |
| import pytest
 | |
| 
 | |
| import ansible.module_utils.basic
 | |
| from ansible.module_utils.six import PY3, string_types
 | |
| from ansible.module_utils._text import to_bytes
 | |
| 
 | |
| 
 | |
| @pytest.mark.parametrize('stdin', [{}], indirect=['stdin'])
 | |
| def test_warn(am, capfd):
 | |
| 
 | |
|     am.warn('warning1')
 | |
| 
 | |
|     with pytest.raises(SystemExit):
 | |
|         am.exit_json(warnings=['warning2'])
 | |
|     out, err = capfd.readouterr()
 | |
|     assert json.loads(out)['warnings'] == ['warning1', 'warning2']
 | |
| 
 | |
| 
 | |
| @pytest.mark.parametrize('stdin', [{}], indirect=['stdin'])
 | |
| def test_deprecate(am, capfd):
 | |
|     am.deprecate('deprecation1')
 | |
|     am.deprecate('deprecation2', '2.3')
 | |
| 
 | |
|     with pytest.raises(SystemExit):
 | |
|         am.exit_json(deprecations=['deprecation3', ('deprecation4', '2.4')])
 | |
| 
 | |
|     out, err = capfd.readouterr()
 | |
|     output = json.loads(out)
 | |
|     assert ('warnings' not in output or output['warnings'] == [])
 | |
|     assert output['deprecations'] == [
 | |
|         {u'msg': u'deprecation1', u'version': None},
 | |
|         {u'msg': u'deprecation2', u'version': '2.3'},
 | |
|         {u'msg': u'deprecation3', u'version': None},
 | |
|         {u'msg': u'deprecation4', u'version': '2.4'},
 | |
|     ]
 | |
| 
 | |
| 
 | |
| @pytest.mark.parametrize('stdin', [{}], indirect=['stdin'])
 | |
| def test_deprecate_without_list(am, capfd):
 | |
|     with pytest.raises(SystemExit):
 | |
|         am.exit_json(deprecations='Simple deprecation warning')
 | |
| 
 | |
|     out, err = capfd.readouterr()
 | |
|     output = json.loads(out)
 | |
|     assert ('warnings' not in output or output['warnings'] == [])
 | |
|     assert output['deprecations'] == [
 | |
|         {u'msg': u'Simple deprecation warning', u'version': None},
 | |
|     ]
 |