mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-24 13:04:00 -07:00
* Adding gitlab group and project acess token modules * Documentation corrections and recreate option change * Documentation corrections * Correcting documentation for return objects
107 lines
4 KiB
Python
107 lines
4 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
# 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 (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
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, "token1")
|
|
self.assertEqual(rvalue, False)
|
|
self.assertIsNotNone(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, "token1")
|
|
self.assertEqual(rvalue, False)
|
|
self.assertIsNotNone(self.moduleUtil.access_token_object)
|
|
|
|
rvalue = self.moduleUtil.revoke_access_token()
|
|
self.assertEqual(rvalue, True)
|