Properly handle FieldAttribute.default if callable (#48992)

* Properly handle FieldAttribute.default if callable

Fixes #48673

* Add changelog...

* Add integration test

* Add aliases file
This commit is contained in:
Martin Krizek 2018-11-26 18:14:46 +01:00 committed by GitHub
parent 46b465283c
commit 48ffd8789f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 20 additions and 2 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- Fix using omit on play keywords (https://github.com/ansible/ansible/issues/48673)

View file

@ -363,6 +363,9 @@ class FieldAttributeBase(with_metaclass(BaseMeta, object)):
# if this evaluated to the omit value, set the value back to # if this evaluated to the omit value, set the value back to
# the default specified in the FieldAttribute and move on # the default specified in the FieldAttribute and move on
if omit_value is not None and value == omit_value: if omit_value is not None and value == omit_value:
if callable(attribute.default):
setattr(self, name, attribute.default())
else:
setattr(self, name, attribute.default) setattr(self, name, attribute.default)
continue continue
@ -545,6 +548,9 @@ class FieldAttributeBase(with_metaclass(BaseMeta, object)):
for (name, attribute) in iteritems(self._valid_attrs): for (name, attribute) in iteritems(self._valid_attrs):
if name in data: if name in data:
setattr(self, name, data[name]) setattr(self, name, data[name])
else:
if callable(attribute.default):
setattr(self, name, attribute.default())
else: else:
setattr(self, name, attribute.default) setattr(self, name, attribute.default)

View file

@ -0,0 +1,4 @@
- hosts: localhost
serial: "{{ testing_omitted_variable | default(omit) }}"
tasks:
- debug:

View file

@ -0,0 +1 @@
shippable/posix/group3

View file

@ -0,0 +1,5 @@
#!/usr/bin/env bash
set -eux
ansible-playbook 48673.yml -i ../../inventory -v "$@"