Server IP : 85.214.239.14 / Your IP : 18.226.172.234 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 : /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 NotificationTemplate, Job def compare_with_encrypted(model_config, param_config): """Given a model_config from the database, assure that this is consistent with the config given in the notification_configuration parameter this requires handling of password fields """ for key, model_val in model_config.items(): param_val = param_config.get(key, 'missing') if isinstance(model_val, str) and (model_val.startswith('$encrypted$') or param_val.startswith('$encrypted$')): assert model_val.startswith('$encrypted$') # must be saved as encrypted assert len(model_val) > len('$encrypted$') else: assert model_val == param_val, 'Config key {0} did not match, (model: {1}, input: {2})'.format(key, model_val, param_val) @pytest.mark.django_db def test_create_modify_notification_template(run_module, admin_user, organization): nt_config = { 'username': 'user', 'password': 'password', 'sender': 'foo@invalid.com', 'recipients': ['foo2@invalid.com'], 'host': 'smtp.example.com', 'port': 25, 'use_tls': False, 'use_ssl': False, 'timeout': 4, } result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='email', notification_configuration=nt_config, ), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert result.pop('changed', None), result nt = NotificationTemplate.objects.get(id=result['id']) compare_with_encrypted(nt.notification_configuration, nt_config) assert nt.organization == organization # Test no-op, this is impossible if the notification_configuration is given # because we cannot determine if password fields changed result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='email', ), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert not result.pop('changed', None), result # Test a change in the configuration nt_config['timeout'] = 12 result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='email', notification_configuration=nt_config, ), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert result.pop('changed', None), result nt.refresh_from_db() compare_with_encrypted(nt.notification_configuration, nt_config) @pytest.mark.django_db def test_invalid_notification_configuration(run_module, admin_user, organization): result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='email', notification_configuration={}, ), admin_user, ) assert result.get('failed', False), result.get('msg', result) assert 'Missing required fields for Notification Configuration' in result['msg'] @pytest.mark.django_db def test_deprecated_to_modern_no_op(run_module, admin_user, organization): nt_config = {'url': 'http://www.example.com/hook', 'headers': {'X-Custom-Header': 'value123'}} result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='webhook', notification_configuration=nt_config, ), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert result.pop('changed', None), result result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='webhook', notification_configuration=nt_config, ), admin_user, ) assert not result.get('failed', False), result.get('msg', result) assert not result.pop('changed', None), result @pytest.mark.django_db def test_build_notification_message_undefined(run_module, admin_user, organization): """Job notification templates may encounter undefined values in the context when they are rendered. Make sure that accessing attributes or items of an undefined value returns another instance of Undefined, rather than raising an UndefinedError. This enables the use of expressions like "{{ job.created_by.first_name | default('unknown') }}".""" job = Job.objects.create(name='foobar') nt_config = {'url': 'http://www.example.com/hook', 'headers': {'X-Custom-Header': 'value123'}} custom_start_template = {'body': '{"started_by": "{{ job.summary_fields.created_by.username | default(\'My Placeholder\') }}"}'} messages = {'started': custom_start_template, 'success': None, 'error': None, 'workflow_approval': None} result = run_module( 'notification_template', dict( name='foo-notification-template', organization=organization.name, notification_type='webhook', notification_configuration=nt_config, messages=messages, ), admin_user, ) nt = NotificationTemplate.objects.get(id=result['id']) body = job.build_notification_message(nt, 'running') assert '{"started_by": "My Placeholder"}' in body[1]