tripleo-ansible/tripleo_ansible/playbooks/cli-baremetal-bios-reset.yaml
Kevin Carter 3cee97deee Normalize how we run validations
This change normalizes how we execute validations by ensuring all validations calls are
running via a shell command and sourcing the `stackrc` file; this is due to validations
not being completely compatible with the OSC clouds config. All validations will now
run when the `run_validations` is set to true. This ensures that the playbook will only
execute validations when instructed to.

Change-Id: Ie1b0c739dc08023a1bba7a98292a8c570b8a2a9c
Signed-off-by: Kevin Carter <kecarter@redhat.com>
2020-05-12 13:33:54 +00:00

76 lines
2.4 KiB
YAML

---
# Copyright 2019 Red Hat, Inc.
# All Rights Reserved.
#
# 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.
- name: Baremetal bios reset for multiple Ironic Nodes
connection: "{{ (tripleo_target_host is defined) | ternary('ssh', 'local') }}"
hosts: "{{ tripleo_target_host | default('localhost') }}"
remote_user: "{{ tripleo_target_user | default(lookup('env', 'USER')) }}"
gather_facts: "{{ (tripleo_target_host is defined) | ternary(true, false) }}"
any_errors_fatal: true
vars:
concurrency: 20
max_retries: 2
node_timeout: 1200
pre_tasks:
- name: Check for required inputs
fail:
msg: >
Input missing `{{ item }}`
when:
- hostvars[inventory_hostname][item] is undefined
loop:
- node_uuids
tasks:
- name: Set node_uuids_reset fact
set_fact:
node_uuids_reset: "{{ node_uuids }}"
# NOTE(cloudnull): This limits the concurrency so that we're not adding
# more threads than needed.
- name: Set concurrency fact
set_fact:
runtime_concurrency: "{{
((concurrency | int) > (node_uuids_reset | length)) |
ternary((node_uuids_reset | length), (concurrency | int))
}}"
- name: exit if nothing to do
block:
- name: Notice
debug:
msg: No nodes are manageable at this time.
- name: end play
meta: end_play
when:
- (node_uuids_reset | length) < 1
- name: Notice
debug:
msg: >-
Running raid config on the following nodes, {{ node_uuids_reset }}.
- name: Start baremetal bios reset
os_baremetal_clean_node:
cloud: undercloud
node_uuid: "{{ node_uuids_reset }}"
concurrency: "{{ runtime_concurrency }}"
timeout: "{{ node_timeout }}"
clean_steps:
- interface: bios
step: factory_reset