2020-03-09 09:11:07 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2022-08-05 12:28:29 +02:00
|
|
|
# Copyright (c) 2019, Guillaume Martinez (lunik@tiwabbit.fr)
|
|
|
|
# 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
|
2020-03-09 09:11:07 +00:00
|
|
|
|
2020-06-25 01:20:36 +05:30
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2022-11-02 21:42:29 +01:00
|
|
|
from ansible_collections.community.general.plugins.modules.gitlab_user import GitLabUser
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
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:
|
2020-03-24 09:27:28 +01:00
|
|
|
from .gitlab import (GitlabModuleTestCase,
|
2020-03-25 12:43:51 +01:00
|
|
|
python_version_match_requirement,
|
|
|
|
resp_find_user, resp_get_user, resp_get_user_keys,
|
|
|
|
resp_create_user_keys, resp_create_user, resp_delete_user,
|
|
|
|
resp_get_member, resp_get_group, resp_add_member,
|
|
|
|
resp_update_member, resp_get_member)
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
# GitLab module requirements
|
|
|
|
if python_version_match_requirement():
|
|
|
|
from gitlab.v4.objects import User
|
|
|
|
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_find_user = _dummy
|
|
|
|
resp_get_user = _dummy
|
|
|
|
resp_get_user_keys = _dummy
|
|
|
|
resp_create_user_keys = _dummy
|
|
|
|
resp_create_user = _dummy
|
|
|
|
resp_delete_user = _dummy
|
|
|
|
resp_get_member = _dummy
|
|
|
|
resp_get_group = _dummy
|
|
|
|
resp_add_member = _dummy
|
|
|
|
resp_update_member = _dummy
|
|
|
|
resp_get_member = _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 TestGitlabUser(GitlabModuleTestCase):
|
|
|
|
def setUp(self):
|
|
|
|
super(TestGitlabUser, self).setUp()
|
|
|
|
|
|
|
|
self.moduleUtil = GitLabUser(module=self.mock_module, gitlab_instance=self.gitlab_instance)
|
|
|
|
|
|
|
|
@with_httmock(resp_find_user)
|
|
|
|
def test_exist_user(self):
|
2021-11-16 13:01:32 +01:00
|
|
|
rvalue = self.moduleUtil.exists_user("john_smith")
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
self.assertEqual(rvalue, True)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
rvalue = self.moduleUtil.exists_user("paul_smith")
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
self.assertEqual(rvalue, False)
|
|
|
|
|
|
|
|
@with_httmock(resp_find_user)
|
|
|
|
def test_find_user(self):
|
2021-11-16 13:01:32 +01:00
|
|
|
user = self.moduleUtil.find_user("john_smith")
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
self.assertEqual(type(user), User)
|
|
|
|
self.assertEqual(user.name, "John Smith")
|
|
|
|
self.assertEqual(user.id, 1)
|
|
|
|
|
|
|
|
@with_httmock(resp_create_user)
|
|
|
|
def test_create_user(self):
|
2021-11-16 13:01:32 +01:00
|
|
|
user = self.moduleUtil.create_user({'email': 'john@example.com', 'password': 's3cur3s3cr3T',
|
2020-03-09 09:11:07 +00:00
|
|
|
'username': 'john_smith', 'name': 'John Smith'})
|
|
|
|
self.assertEqual(type(user), User)
|
|
|
|
self.assertEqual(user.name, "John Smith")
|
|
|
|
self.assertEqual(user.id, 1)
|
|
|
|
|
|
|
|
@with_httmock(resp_get_user)
|
|
|
|
def test_update_user(self):
|
|
|
|
user = self.gitlab_instance.users.get(1)
|
2021-02-09 10:29:13 +01:00
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
changed, newUser = self.moduleUtil.update_user(
|
2021-02-09 10:29:13 +01:00
|
|
|
user,
|
|
|
|
{'name': {'value': "Jack Smith"}, "is_admin": {'value': "true", 'setter': 'admin'}}, {}
|
|
|
|
)
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
self.assertEqual(changed, True)
|
|
|
|
self.assertEqual(newUser.name, "Jack Smith")
|
2021-02-09 10:29:13 +01:00
|
|
|
self.assertEqual(newUser.admin, "true")
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
changed, newUser = self.moduleUtil.update_user(user, {'name': {'value': "Jack Smith"}}, {})
|
2021-02-09 10:29:13 +01:00
|
|
|
|
|
|
|
self.assertEqual(changed, False)
|
2020-03-09 09:11:07 +00:00
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
changed, newUser = self.moduleUtil.update_user(
|
2021-02-09 10:29:13 +01:00
|
|
|
user,
|
|
|
|
{}, {
|
|
|
|
'skip_reconfirmation': {'value': True},
|
|
|
|
'password': {'value': 'super_secret-super_secret'},
|
|
|
|
}
|
|
|
|
)
|
2020-03-09 09:11:07 +00:00
|
|
|
|
2021-02-09 10:29:13 +01:00
|
|
|
# note: uncheckable parameters dont set changed state
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(changed, False)
|
2021-02-09 10:29:13 +01:00
|
|
|
self.assertEqual(newUser.skip_reconfirmation, True)
|
|
|
|
self.assertEqual(newUser.password, 'super_secret-super_secret')
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
@with_httmock(resp_find_user)
|
|
|
|
@with_httmock(resp_delete_user)
|
|
|
|
def test_delete_user(self):
|
2021-11-16 13:01:32 +01:00
|
|
|
self.moduleUtil.exists_user("john_smith")
|
|
|
|
rvalue = self.moduleUtil.delete_user()
|
2020-03-09 09:11:07 +00:00
|
|
|
|
|
|
|
self.assertEqual(rvalue, None)
|
|
|
|
|
|
|
|
@with_httmock(resp_get_user)
|
|
|
|
@with_httmock(resp_get_user_keys)
|
|
|
|
def test_sshkey_exist(self):
|
|
|
|
user = self.gitlab_instance.users.get(1)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
exist = self.moduleUtil.ssh_key_exists(user, "Public key")
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(exist, True)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
notExist = self.moduleUtil.ssh_key_exists(user, "Private key")
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(notExist, False)
|
|
|
|
|
|
|
|
@with_httmock(resp_get_user)
|
|
|
|
@with_httmock(resp_create_user_keys)
|
|
|
|
@with_httmock(resp_get_user_keys)
|
|
|
|
def test_create_sshkey(self):
|
|
|
|
user = self.gitlab_instance.users.get(1)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
rvalue = self.moduleUtil.add_ssh_key_to_user(user, {
|
2020-03-09 09:11:07 +00:00
|
|
|
'name': "Public key",
|
|
|
|
'file': "ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAIEAiPWx6WM4lhHNedGfBpPJNPpZ7yKu+dnn1SJe"
|
|
|
|
"jgt4596k6YjzGGphH2TUxwKzxcKDKKezwkpfnxPkSMkuEspGRt/aZZ9wa++Oi7Qkr8prgHc4"
|
2021-05-14 12:30:59 +04:30
|
|
|
"soW6NUlfDzpvZK2H5E7eQaSeP3SAwGmQKUFHCddNaP0L+hM7zhFNzjFvpaMgJw0=",
|
|
|
|
'expires_at': ""})
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(rvalue, False)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
rvalue = self.moduleUtil.add_ssh_key_to_user(user, {
|
2020-03-09 09:11:07 +00:00
|
|
|
'name': "Private key",
|
|
|
|
'file': "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDA1YotVDm2mAyk2tPt4E7AHm01sS6JZmcU"
|
|
|
|
"dRuSuA5zszUJzYPPUSRAX3BCgTqLqYx//UuVncK7YqLVSbbwjKR2Ez5lISgCnVfLVEXzwhv+"
|
|
|
|
"xawxKWmI7hJ5S0tOv6MJ+IxyTa4xcKwJTwB86z22n9fVOQeJTR2dSOH1WJrf0PvRk+KVNY2j"
|
|
|
|
"TiGHTi9AIjLnyD/jWRpOgtdfkLRc8EzAWrWlgNmH2WOKBw6za0az6XoG75obUdFVdW3qcD0x"
|
2021-05-14 12:30:59 +04:30
|
|
|
"c809OHLi7FDf+E7U4wiZJCFuUizMeXyuK/SkaE1aee4Qp5R4dxTR4TP9M1XAYkf+kF0W9srZ+mhF069XD/zhUPJsvwEF",
|
|
|
|
'expires_at': "2027-01-01"})
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(rvalue, True)
|
|
|
|
|
|
|
|
@with_httmock(resp_get_group)
|
|
|
|
@with_httmock(resp_get_member)
|
|
|
|
def test_find_member(self):
|
|
|
|
group = self.gitlab_instance.groups.get(1)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
user = self.moduleUtil.find_member(group, 1)
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(user.username, "raymond_smith")
|
|
|
|
|
|
|
|
@with_httmock(resp_get_user)
|
|
|
|
@with_httmock(resp_get_group)
|
|
|
|
@with_httmock(resp_get_group)
|
|
|
|
@with_httmock(resp_get_member)
|
|
|
|
@with_httmock(resp_add_member)
|
|
|
|
@with_httmock(resp_update_member)
|
|
|
|
def test_assign_user_to_group(self):
|
|
|
|
group = self.gitlab_instance.groups.get(1)
|
|
|
|
user = self.gitlab_instance.users.get(1)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
rvalue = self.moduleUtil.assign_user_to_group(user, group.id, "developer")
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(rvalue, False)
|
|
|
|
|
2021-11-16 13:01:32 +01:00
|
|
|
rvalue = self.moduleUtil.assign_user_to_group(user, group.id, "guest")
|
2020-03-09 09:11:07 +00:00
|
|
|
self.assertEqual(rvalue, True)
|