mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 21:14:00 -07:00 
			
		
		
		
	
		
			Some checks are pending
		
		
	
	EOL CI / EOL Sanity (Ⓐ2.17) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.10) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.12) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.7) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/3/) (push) Waiting to run
				
			nox / Run extra sanity tests (push) Waiting to run
				
			* Adjust all __future__ imports: for i in $(grep -REl "__future__.*absolute_import" plugins/ tests/); do sed -e 's/from __future__ import .*/from __future__ import annotations/g' -i $i; done * Remove all UTF-8 encoding specifications for Python source files: for i in $(grep -REl '[-][*]- coding: utf-8 -[*]-' plugins/ tests/); do sed -e '/^# -\*- coding: utf-8 -\*-/d' -i $i; done * Remove __metaclass__ = type: for i in $(grep -REl '__metaclass__ = type' plugins/ tests/); do sed -e '/^__metaclass__ = type/d' -i $i; done
		
			
				
	
	
		
			129 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| # Copyright (c) 2023, Zoran Krleza (zoran.krleza@true-north.hr)
 | |
| # 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 annotations
 | |
| 
 | |
| import pytest
 | |
| import gitlab
 | |
| 
 | |
| from ansible_collections.community.general.plugins.modules.gitlab_group_access_token import GitLabGroupAccessToken
 | |
| 
 | |
| # python-gitlab 3.1+ is needed for python-gitlab access tokens api
 | |
| PYTHON_GITLAB_MINIMAL_VERSION = (3, 1)
 | |
| 
 | |
| 
 | |
| def python_gitlab_version_match_requirement():
 | |
|     return tuple(map(int, gitlab.__version__.split('.'))) >= PYTHON_GITLAB_MINIMAL_VERSION
 | |
| 
 | |
| 
 | |
| def _dummy(x):
 | |
|     """Dummy function.  Only used as a placeholder for toplevel definitions when the test is going
 | |
|     to be skipped anyway"""
 | |
|     return x
 | |
| 
 | |
| 
 | |
| pytestmark = []
 | |
| try:
 | |
|     from .gitlab import (GitlabModuleTestCase,
 | |
|                          resp_get_user,
 | |
|                          resp_get_group,
 | |
|                          resp_list_group_access_tokens,
 | |
|                          resp_create_group_access_tokens,
 | |
|                          resp_revoke_group_access_tokens)
 | |
| 
 | |
| except ImportError:
 | |
|     pytestmark.append(pytest.mark.skip("Could not load gitlab module required for testing"))
 | |
|     # Need to set these to something so that we don't fail when parsing
 | |
|     GitlabModuleTestCase = object
 | |
|     resp_list_group_access_tokens = _dummy
 | |
|     resp_create_group_access_tokens = _dummy
 | |
|     resp_revoke_group_access_tokens = _dummy
 | |
|     resp_get_user = _dummy
 | |
|     resp_get_group = _dummy
 | |
| 
 | |
| # Unit tests requirements
 | |
| try:
 | |
|     from httmock import with_httmock  # noqa
 | |
| except ImportError:
 | |
|     pytestmark.append(pytest.mark.skip("Could not load httmock module required for testing"))
 | |
|     with_httmock = _dummy
 | |
| 
 | |
| 
 | |
| class TestGitlabGroupAccessToken(GitlabModuleTestCase):
 | |
|     @with_httmock(resp_get_user)
 | |
|     def setUp(self):
 | |
|         super(TestGitlabGroupAccessToken, self).setUp()
 | |
|         if not python_gitlab_version_match_requirement():
 | |
|             self.skipTest("python-gitlab %s+ is needed for gitlab_group_access_token" % ",".join(map(str, PYTHON_GITLAB_MINIMAL_VERSION)))
 | |
| 
 | |
|         self.moduleUtil = GitLabGroupAccessToken(module=self.mock_module, gitlab_instance=self.gitlab_instance)
 | |
| 
 | |
|     @with_httmock(resp_get_group)
 | |
|     @with_httmock(resp_list_group_access_tokens)
 | |
|     def test_find_access_token(self):
 | |
|         group = self.gitlab_instance.groups.get(1)
 | |
|         self.assertIsNotNone(group)
 | |
| 
 | |
|         rvalue = self.moduleUtil.find_access_token(group, "test-token")
 | |
|         self.assertEqual(rvalue, False)
 | |
|         self.assertIsNotNone(self.moduleUtil.access_token_object)
 | |
|         self.assertEqual(self.moduleUtil.access_token_object.id, 691)
 | |
|         self.assertFalse(self.moduleUtil.access_token_object.revoked)
 | |
| 
 | |
|     @with_httmock(resp_get_group)
 | |
|     @with_httmock(resp_list_group_access_tokens)
 | |
|     def test_find_access_token_old_format(self):
 | |
|         group = self.gitlab_instance.groups.get(1)
 | |
|         self.assertIsNotNone(group)
 | |
| 
 | |
|         rvalue = self.moduleUtil.find_access_token(group, "test-token-no-revoked")
 | |
|         self.assertEqual(rvalue, False)
 | |
|         self.assertIsNotNone(self.moduleUtil.access_token_object)
 | |
|         self.assertEqual(self.moduleUtil.access_token_object.id, 695)
 | |
|         self.assertFalse(hasattr(self.moduleUtil.access_token_object, "revoked"))
 | |
| 
 | |
|     @with_httmock(resp_get_group)
 | |
|     @with_httmock(resp_list_group_access_tokens)
 | |
|     def test_find_revoked_access_token(self):
 | |
|         group = self.gitlab_instance.groups.get(1)
 | |
|         self.assertIsNotNone(group)
 | |
| 
 | |
|         rvalue = self.moduleUtil.find_access_token(group, "test-token-three")
 | |
|         self.assertEqual(rvalue, False)
 | |
|         self.assertIsNone(self.moduleUtil.access_token_object)
 | |
| 
 | |
|     @with_httmock(resp_get_group)
 | |
|     @with_httmock(resp_list_group_access_tokens)
 | |
|     def test_find_access_token_negative(self):
 | |
|         groups = self.gitlab_instance.groups.get(1)
 | |
|         self.assertIsNotNone(groups)
 | |
| 
 | |
|         rvalue = self.moduleUtil.find_access_token(groups, "nonexisting")
 | |
|         self.assertEqual(rvalue, False)
 | |
|         self.assertIsNone(self.moduleUtil.access_token_object)
 | |
| 
 | |
|     @with_httmock(resp_get_group)
 | |
|     @with_httmock(resp_create_group_access_tokens)
 | |
|     def test_create_access_token(self):
 | |
|         groups = self.gitlab_instance.groups.get(1)
 | |
|         self.assertIsNotNone(groups)
 | |
| 
 | |
|         rvalue = self.moduleUtil.create_access_token(groups, {'name': "tokenXYZ", 'scopes': ["api"], 'access_level': 20, 'expires_at': "2024-12-31"})
 | |
|         self.assertEqual(rvalue, True)
 | |
|         self.assertIsNotNone(self.moduleUtil.access_token_object)
 | |
| 
 | |
|     @with_httmock(resp_get_group)
 | |
|     @with_httmock(resp_list_group_access_tokens)
 | |
|     @with_httmock(resp_revoke_group_access_tokens)
 | |
|     def test_revoke_access_token(self):
 | |
|         groups = self.gitlab_instance.groups.get(1)
 | |
|         self.assertIsNotNone(groups)
 | |
| 
 | |
|         rvalue = self.moduleUtil.find_access_token(groups, "test-token")
 | |
|         self.assertEqual(rvalue, False)
 | |
|         self.assertIsNotNone(self.moduleUtil.access_token_object)
 | |
| 
 | |
|         rvalue = self.moduleUtil.revoke_access_token()
 | |
|         self.assertEqual(rvalue, True)
 |