mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	EOL CI / EOL Sanity (Ⓐ2.15) (push) Has been cancelled
				
			EOL CI / EOL Units (Ⓐ2.15+py2.7) (push) Has been cancelled
				
			EOL CI / EOL Units (Ⓐ2.15+py3.10) (push) Has been cancelled
				
			EOL CI / EOL Units (Ⓐ2.15+py3.5) (push) Has been cancelled
				
			EOL CI / EOL I (Ⓐ2.15+alpine3+py:azp/posix/1/) (push) Has been cancelled
				
			EOL CI / EOL I (Ⓐ2.15+alpine3+py:azp/posix/2/) (push) Has been cancelled
				
			EOL CI / EOL I (Ⓐ2.15+alpine3+py:azp/posix/3/) (push) Has been cancelled
				
			EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/1/) (push) Has been cancelled
				
			EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/2/) (push) Has been cancelled
				
			EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/3/) (push) Has been cancelled
				
			import-galaxy / Test to import built collection artifact with Galaxy importer (push) Has been cancelled
				
			Verify REUSE / check (push) Has been cancelled
				
			* Replace compat with equivalent from community.internal_test_tools. * Replace mock with equivalent from community.internal_test_tools.
		
			
				
	
	
		
			239 lines
		
	
	
	
		
			9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			239 lines
		
	
	
	
		
			9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) Ansible project
 | |
| # GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| # SPDX-License-Identifier: GPL-3.0-or-later
 | |
| 
 | |
| from __future__ import (absolute_import, division, print_function)
 | |
| __metaclass__ = type
 | |
| 
 | |
| from ansible_collections.community.internal_test_tools.tests.unit.compat import unittest
 | |
| from ansible_collections.community.internal_test_tools.tests.unit.compat.mock import patch
 | |
| from ansible.module_utils import basic
 | |
| from ansible_collections.community.general.plugins.modules import jenkins_build
 | |
| from ansible_collections.community.internal_test_tools.tests.unit.plugins.modules.utils import (
 | |
|     AnsibleExitJson,
 | |
|     AnsibleFailJson,
 | |
|     set_module_args,
 | |
|     exit_json,
 | |
|     fail_json,
 | |
| )
 | |
| 
 | |
| 
 | |
| class jenkins:
 | |
|     class JenkinsException(Exception):
 | |
|         pass
 | |
| 
 | |
|     class NotFoundException(JenkinsException):
 | |
|         pass
 | |
| 
 | |
| 
 | |
| class JenkinsBuildMock():
 | |
|     def get_build_status(self):
 | |
|         try:
 | |
|             instance = JenkinsMock()
 | |
|             response = JenkinsMock.get_build_info(instance, 'host-delete', 1234)
 | |
|             return response
 | |
|         except jenkins.JenkinsException as e:
 | |
|             response = {}
 | |
|             response["result"] = "ABSENT"
 | |
|             return response
 | |
|         except Exception as e:
 | |
|             fail_json(msg='Unable to fetch build information, {0}'.format(e))
 | |
| 
 | |
| 
 | |
| class JenkinsMock():
 | |
| 
 | |
|     def get_job_info(self, name):
 | |
|         return {
 | |
|             "nextBuildNumber": 1234
 | |
|         }
 | |
| 
 | |
|     def get_build_info(self, name, build_number):
 | |
|         if name == "host-delete":
 | |
|             raise jenkins.JenkinsException("job {0} number {1} does not exist".format(name, build_number))
 | |
|         elif name == "create-detached":
 | |
|             return {
 | |
|                 "building": True,
 | |
|                 "result": None
 | |
|             }
 | |
|         return {
 | |
|             "building": True,
 | |
|             "result": "SUCCESS"
 | |
|         }
 | |
| 
 | |
|     def build_job(self, *args):
 | |
|         return None
 | |
| 
 | |
|     def delete_build(self, name, build_number):
 | |
|         return None
 | |
| 
 | |
|     def stop_build(self, name, build_number):
 | |
|         return None
 | |
| 
 | |
| 
 | |
| class JenkinsMockIdempotent():
 | |
| 
 | |
|     def get_job_info(self, name):
 | |
|         return {
 | |
|             "nextBuildNumber": 1235
 | |
|         }
 | |
| 
 | |
|     def get_build_info(self, name, build_number):
 | |
|         return {
 | |
|             "building": False,
 | |
|             "result": "ABORTED"
 | |
|         }
 | |
| 
 | |
|     def build_job(self, *args):
 | |
|         return None
 | |
| 
 | |
|     def delete_build(self, name, build_number):
 | |
|         raise jenkins.NotFoundException("job {0} number {1} does not exist".format(name, build_number))
 | |
| 
 | |
|     def stop_build(self, name, build_number):
 | |
|         return None
 | |
| 
 | |
| 
 | |
| class TestJenkinsBuild(unittest.TestCase):
 | |
| 
 | |
|     def setUp(self):
 | |
|         self.mock_module_helper = patch.multiple(basic.AnsibleModule,
 | |
|                                                  exit_json=exit_json,
 | |
|                                                  fail_json=fail_json)
 | |
|         self.mock_module_helper.start()
 | |
|         self.addCleanup(self.mock_module_helper.stop)
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     def test_module_fail_when_required_args_missing(self, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         with self.assertRaises(AnsibleFailJson):
 | |
|             with set_module_args({}):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     def test_module_fail_when_missing_build_number(self, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         with self.assertRaises(AnsibleFailJson):
 | |
|             with set_module_args({
 | |
|                 "name": "required-if",
 | |
|                 "state": "stopped"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     def test_module_create_build(self, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMock()
 | |
| 
 | |
|         with self.assertRaises(AnsibleExitJson):
 | |
|             with set_module_args({
 | |
|                 "name": "host-check",
 | |
|                 "user": "abc",
 | |
|                 "token": "xyz"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     def test_module_stop_build(self, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMock()
 | |
| 
 | |
|         with self.assertRaises(AnsibleExitJson) as return_json:
 | |
|             with set_module_args({
 | |
|                 "name": "host-check",
 | |
|                 "build_number": "1234",
 | |
|                 "state": "stopped",
 | |
|                 "user": "abc",
 | |
|                 "token": "xyz"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|         self.assertTrue(return_json.exception.args[0]['changed'])
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     def test_module_stop_build_again(self, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMockIdempotent()
 | |
| 
 | |
|         with self.assertRaises(AnsibleExitJson) as return_json:
 | |
|             with set_module_args({
 | |
|                 "name": "host-check",
 | |
|                 "build_number": "1234",
 | |
|                 "state": "stopped",
 | |
|                 "user": "abc",
 | |
|                 "password": "xyz"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|         self.assertFalse(return_json.exception.args[0]['changed'])
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_build_status')
 | |
|     def test_module_delete_build(self, build_status, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMock()
 | |
|         build_status.return_value = JenkinsBuildMock().get_build_status()
 | |
| 
 | |
|         with self.assertRaises(AnsibleExitJson):
 | |
|             with set_module_args({
 | |
|                 "name": "host-delete",
 | |
|                 "build_number": "1234",
 | |
|                 "state": "absent",
 | |
|                 "user": "abc",
 | |
|                 "token": "xyz"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     def test_module_delete_build_again(self, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMockIdempotent()
 | |
| 
 | |
|         with self.assertRaises(AnsibleFailJson):
 | |
|             with set_module_args({
 | |
|                 "name": "host-delete",
 | |
|                 "build_number": "1234",
 | |
|                 "state": "absent",
 | |
|                 "user": "abc",
 | |
|                 "token": "xyz"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_build_status')
 | |
|     def test_module_create_build_without_detach(self, build_status, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMock()
 | |
|         build_status.return_value = JenkinsBuildMock().get_build_status()
 | |
| 
 | |
|         with self.assertRaises(AnsibleExitJson) as return_json:
 | |
|             with set_module_args({
 | |
|                 "name": "create-detached",
 | |
|                 "user": "abc",
 | |
|                 "token": "xyz"
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|         self.assertFalse(return_json.exception.args[0]['changed'])
 | |
| 
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.test_dependencies')
 | |
|     @patch('ansible_collections.community.general.plugins.modules.jenkins_build.JenkinsBuild.get_jenkins_connection')
 | |
|     def test_module_create_build_detached(self, jenkins_connection, test_deps):
 | |
|         test_deps.return_value = None
 | |
|         jenkins_connection.return_value = JenkinsMock()
 | |
| 
 | |
|         with self.assertRaises(AnsibleExitJson) as return_json:
 | |
|             with set_module_args({
 | |
|                 "name": "create-detached",
 | |
|                 "user": "abc",
 | |
|                 "token": "xyz",
 | |
|                 "detach": True
 | |
|             }):
 | |
|                 jenkins_build.main()
 | |
| 
 | |
|         self.assertTrue(return_json.exception.args[0]['changed'])
 |