diff options
author | James Cammarata <jimi@sngx.net> | 2016-08-04 00:05:30 -0500 |
---|---|---|
committer | James Cammarata <jimi@sngx.net> | 2016-08-04 15:04:10 -0500 |
commit | 159aa26b36a6455ebc38d527c294c60899892c04 (patch) | |
tree | 3488df31808fa1fc99f507f9ff342554fe0a8dee /lib/ansible/utils/helpers.py | |
parent | 3a83333ef2cfa2045719bc957f42ceda75aeabef (diff) | |
download | ansible-159aa26b36a6455ebc38d527c294c60899892c04.tar.gz |
FEATURE: adding variable serial batches
This feature changes the scalar value of `serial:` to a list, which
allows users to specify a list of values, so batches can be ramped
up (commonly called "canary" setups):
- hosts: all
serial: [1, 5, 10, "100%"]
tasks:
...
Diffstat (limited to 'lib/ansible/utils/helpers.py')
-rw-r--r-- | lib/ansible/utils/helpers.py | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/ansible/utils/helpers.py b/lib/ansible/utils/helpers.py new file mode 100644 index 0000000000..10e88aa6ce --- /dev/null +++ b/lib/ansible/utils/helpers.py @@ -0,0 +1,34 @@ +# (c) 2016, Ansible by Red Hat <support@ansible.com> +# +# This file is part of Ansible +# +# Ansible is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Ansible is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Ansible. If not, see <http://www.gnu.org/licenses/>. + +# Make coding more python3-ish +from __future__ import (absolute_import, division, print_function) +__metaclass__ = type + +from ansible.compat.six import string_types + +def pct_to_int(value, num_items, min_value=1): + ''' + Converts a given value to a percentage if specified as "x%", + otherwise converts the given value to an integer. + ''' + if isinstance(value, string_types) and value.endswith('%'): + value_pct = int(value.replace("%","")) + return int((value_pct/100.0) * num_items) or min_value + else: + return int(value) + |