From c7c51d5100e8eba93337c34bd9eb101ec4cf70df Mon Sep 17 00:00:00 2001 From: Malanik Jan Date: Tue, 18 Jul 2017 12:54:10 -0400 Subject: yardstick setup ansible, including load_images also update to cirros 0.3.5 added PROX compilation add create_node_pod_yaml role JIRA: YARDSTICK-639 Change-Id: If5999841287a54c7e5c64a7cc487c6394df90424 Signed-off-by: Malanik Jan Signed-off-by: Ross Brattain --- ansible/filter_plugins/fuel_lookups.py | 54 ++++++++++++++++++++++++++++++++++ ansible/filter_plugins/networks.py | 38 ++++++++++++++++++++++++ 2 files changed, 92 insertions(+) create mode 100644 ansible/filter_plugins/fuel_lookups.py create mode 100644 ansible/filter_plugins/networks.py (limited to 'ansible/filter_plugins') diff --git a/ansible/filter_plugins/fuel_lookups.py b/ansible/filter_plugins/fuel_lookups.py new file mode 100644 index 000000000..ac52401e8 --- /dev/null +++ b/ansible/filter_plugins/fuel_lookups.py @@ -0,0 +1,54 @@ +# Copyright (c) 2017 Intel Corporation +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +def do_find_fuel_nodes(fuel_nodes): + ips = {} + for fuel_node in fuel_nodes: + if 'controller' in fuel_node['roles']: + ips.setdefault("controller_ids", []).append(fuel_node['id']) + ips.setdefault("controllers_ips", []).append(fuel_node['ip']) + if 'compute' in fuel_node['roles']: + ips.setdefault("compute_ids", []).append(fuel_node['id']) + ips.setdefault("computes_ips", []).append(fuel_node['ip']) + return ips + +# def do_find_fuel_nodes(fuel_output): +# ips = {} +# for l in fuel_output.splitlines(): +# splits = l.splti() +# if 'controller' in l: +# ips["controller_ids"] = splits[0] +# ips["controllers_ips"] = splits[9] +# if 'compute' in l: +# ips["compute_ids"] = splits[0] +# ips["computes_ips"] = splits[9] +# return ips + + +class FilterModule(object): + def filters(self): + return { + 'find_fuel_nodes': do_find_fuel_nodes, + } + + +SAMPLE = """\ +id | status | name | cluster | ip | mac | roles | pending_roles | online | group_id +---+--------+------------------+---------+-----------+-------------------+----------------------+---------------+--------+--------- + 4 | ready | Untitled (9a:b1) | 1 | 10.20.0.6 | 0c:c4:7a:75:9a:b1 | ceph-osd, compute | | 1 | 1 + 1 | ready | Untitled (9a:ab) | 1 | 10.20.0.4 | 0c:c4:7a:75:9a:ab | ceph-osd, controller | | 1 | 1 + 5 | ready | Untitled (9a:1b) | 1 | 10.20.0.7 | 0c:c4:7a:75:9a:1b | ceph-osd, compute | | 1 | 1 + 2 | ready | Untitled (9a:67) | 1 | 10.20.0.3 | 0c:c4:7a:75:9a:67 | controller | | 1 | 1 + 3 | ready | Untitled (99:d7) | 1 | 10.20.0.5 | 0c:c4:7a:75:99:d7 | controller, mongo | | 1 | 1 +""" \ No newline at end of file diff --git a/ansible/filter_plugins/networks.py b/ansible/filter_plugins/networks.py new file mode 100644 index 000000000..a1573951f --- /dev/null +++ b/ansible/filter_plugins/networks.py @@ -0,0 +1,38 @@ +# Copyright (c) 2017 Intel Corporation +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + + +from urlparse import urlsplit + + +def do_prefix_to_netmask(arg): + return '.'.join(str((0xffffffff << (32 - int(arg)) >> i) & 0xff) for i in + range(24, -8, -8)) + + +def do_netmask_to_prefix(arg): + return sum([bin(int(x)).count('1') for x in arg.split('.')]) + + +def do_urlsplit(arg): + return urlsplit(arg) + + +class FilterModule(object): + def filters(self): + return { + 'prefix_to_netmask': do_prefix_to_netmask, + 'netmask_to_prefix': do_netmask_to_prefix, + 'urlsplit': do_urlsplit, + } -- cgit 1.2.3-korg