Server IP : 85.214.239.14 / Your IP : 3.17.110.91 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /usr/lib/python3/dist-packages/ansible_collections/awx/awx/test/awx/ |
Upload File : |
from __future__ import absolute_import, division, print_function __metaclass__ = type import pytest from awx.main.models import Credential, CredentialType, Organization @pytest.fixture def cred_type(): # Make a credential type which will be used by the credential ct = CredentialType.objects.create( name='Ansible Galaxy Token', inputs={"fields": [{"id": "token", "type": "string", "secret": True, "label": "Ansible Galaxy Secret Token Value"}], "required": ["token"]}, injectors={ "extra_vars": { "galaxy_token": "{{token}}", } }, ) return ct @pytest.mark.django_db def test_create_machine_credential(run_module, admin_user, organization): Organization.objects.create(name='test-org') # create the ssh credential type ct = CredentialType.defaults['ssh']() ct.save() # Example from docs result = run_module( 'credential', dict(name='Test Machine Credential', organization=organization.name, credential_type='Machine', state='present'), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert result.get('changed'), result cred = Credential.objects.get(name='Test Machine Credential') assert cred.credential_type == ct assert result['name'] == "Test Machine Credential" assert result['id'] == cred.pk @pytest.mark.django_db def test_create_vault_credential(run_module, admin_user, organization): # https://github.com/ansible/ansible/issues/61324 Organization.objects.create(name='test-org') ct = CredentialType.defaults['vault']() ct.save() result = run_module( 'credential', dict(name='Test Vault Credential', organization=organization.name, credential_type='Vault', inputs={'vault_id': 'bar', 'vault_password': 'foobar'}, state='present'), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert result.get('changed'), result cred = Credential.objects.get(name='Test Vault Credential') assert cred.credential_type == ct assert 'vault_id' in cred.inputs assert 'vault_password' in cred.inputs assert result['name'] == "Test Vault Credential" assert result['id'] == cred.pk @pytest.mark.django_db def test_missing_credential_type(run_module, admin_user, organization): Organization.objects.create(name='test-org') result = run_module('credential', dict(name='A credential', organization=organization.name, credential_type='foobar', state='present'), admin_user) assert result.get('failed', False), result assert 'credential_type' in result['msg'] assert 'foobar' in result['msg'] assert 'returned 0 items, expected 1' in result['msg'] @pytest.mark.django_db def test_make_use_of_custom_credential_type(run_module, organization, admin_user, cred_type): result = run_module( 'credential', dict(name='Galaxy Token for Steve', organization=organization.name, credential_type=cred_type.name, inputs={'token': '7rEZK38DJl58A7RxA6EC7lLvUHbBQ1'}), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert result.get('changed', False), result cred = Credential.objects.get(name='Galaxy Token for Steve') assert cred.credential_type_id == cred_type.id assert list(cred.inputs.keys()) == ['token'] assert cred.inputs['token'].startswith('$encrypted$') assert len(cred.inputs['token']) >= len('$encrypted$') + len('7rEZK38DJl58A7RxA6EC7lLvUHbBQ1') assert result['name'] == "Galaxy Token for Steve" assert result['id'] == cred.pk @pytest.mark.django_db @pytest.mark.parametrize('update_secrets', [True, False]) def test_secret_field_write_twice(run_module, organization, admin_user, cred_type, update_secrets): val1 = '7rEZK38DJl58A7RxA6EC7lLvUHbBQ1' val2 = '7rEZ238DJl5837rxA6xxxlLvUHbBQ1' for val in (val1, val2): result = run_module( 'credential', dict( name='Galaxy Token for Steve', organization=organization.name, credential_type=cred_type.name, inputs={'token': val}, update_secrets=update_secrets, ), admin_user, ) assert not result.get('failed', False), result.get('msg', result) if update_secrets: assert Credential.objects.get(id=result['id']).get_input('token') == val if update_secrets: assert result.get('changed'), result else: assert result.get('changed') is False, result assert Credential.objects.get(id=result['id']).get_input('token') == val1