1
0
mirror of https://github.com/ansible/awx.git synced 2024-11-01 16:51:11 +03:00

Merge pull request #7095 from AlanCoding/schedule_validation

Add various validation for schedule extra_data
This commit is contained in:
Alan Rominger 2017-07-20 09:30:29 -04:00 committed by GitHub
commit c038116626
2 changed files with 30 additions and 0 deletions

View File

@ -3444,6 +3444,24 @@ class ScheduleSerializer(BaseSerializer):
'Schedule its source project `{}` instead.'.format(value.source_project.name)))
return value
def validate_extra_data(self, value):
if isinstance(value, dict):
return value
return vars_validate_or_raise(value)
def validate(self, attrs):
extra_data = parse_yaml_or_json(attrs.get('extra_data', {}))
if extra_data:
ujt = None
if 'unified_job_template' in attrs:
ujt = attrs['unified_job_template']
elif self.instance:
ujt = self.instance.unified_job_template
if ujt and isinstance(ujt, (Project, InventorySource)):
raise serializers.ValidationError({'extra_data': _(
'Projects and inventory updates cannot accept extra variables.')})
return super(ScheduleSerializer, self).validate(attrs)
# We reject rrules if:
# - DTSTART is not include
# - INTERVAL is not included

View File

@ -0,0 +1,12 @@
import pytest
from awx.api.versioning import reverse
@pytest.mark.django_db
def test_non_job_extra_vars_prohibited(post, project, admin_user):
rrule = 'DTSTART:20151117T050000Z RRULE:FREQ=DAILY;INTERVAL=1;COUNT=1'
url = reverse('api:project_schedules_list', kwargs={'pk': project.id})
r = post(url, {'name': 'test sch', 'rrule': rrule, 'extra_data': '{"a": 5}'},
admin_user, expect=400)
assert 'cannot accept extra variables' in r.data['extra_data'][0]