mirror of
https://github.com/ansible/awx.git
synced 2026-02-17 19:20:05 -03:30
79 lines
2.5 KiB
Python
79 lines
2.5 KiB
Python
import pytest
|
|
|
|
from awx.main.access import CredentialAccess
|
|
from awx.main.models.credential import Credential
|
|
from django.contrib.auth.models import User
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_credential_use_role(credential, user, permissions):
|
|
u = user('user', False)
|
|
credential.use_role.members.add(u)
|
|
assert u in credential.use_role
|
|
|
|
|
|
def test_credential_access_superuser():
|
|
u = User(username='admin', is_superuser=True)
|
|
access = CredentialAccess(u)
|
|
credential = Credential()
|
|
|
|
assert access.can_add(None)
|
|
assert access.can_change(credential, None)
|
|
assert access.can_delete(credential)
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_credential_access_auditor(credential, organization_factory):
|
|
objects = organization_factory("org_cred_auditor",
|
|
users=["user1"],
|
|
roles=['org_cred_auditor.auditor_role:user1'])
|
|
credential.organization = objects.organization
|
|
credential.save()
|
|
|
|
access = CredentialAccess(objects.users.user1)
|
|
assert access.can_read(credential)
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_credential_access_member(alice, credential):
|
|
credential.admin_role.members.add(alice)
|
|
access = CredentialAccess(alice)
|
|
assert access.can_change(credential, {
|
|
'description': 'New description.',
|
|
'organization': None})
|
|
|
|
|
|
@pytest.mark.django_db
|
|
@pytest.mark.parametrize("role_name", ["admin_role", "credential_admin_role"])
|
|
def test_org_credential_access_admin(role_name, alice, org_credential):
|
|
role = getattr(org_credential.organization, role_name)
|
|
role.members.add(alice)
|
|
|
|
access = CredentialAccess(alice)
|
|
|
|
# Alice should be able to PATCH if organization is not changed
|
|
assert access.can_change(org_credential, {
|
|
'description': 'New description.',
|
|
'organization': org_credential.organization.pk})
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_org_credential_access_member(alice, org_credential):
|
|
org_credential.admin_role.members.add(alice)
|
|
|
|
access = CredentialAccess(alice)
|
|
|
|
# Alice should be able to PATCH if organization is not changed
|
|
assert access.can_change(org_credential, {
|
|
'description': 'New description.',
|
|
'organization': org_credential.organization.pk})
|
|
assert access.can_change(org_credential, {
|
|
'description': 'New description.'})
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_cred_no_org(user, credential):
|
|
su = user('su', True)
|
|
access = CredentialAccess(su)
|
|
assert access.can_change(credential, {'user': su.pk})
|