tripleo-ansible/tripleo_ansible/playbooks/cli-baremetal-raid.yaml
ramishra 48cce25c19 Remove hardcoded cloud_name and auth_type used
We use stackrc which sets OS_CLOUD env variable, when running
the cli playbooks. We've been removing hardcoded cloud_names
specified in playbooks to not conflict with it.

Also, 'auth_type' would be picked from clouds.yaml and not
required to be passed an argument.

For standalone ironic using noauth, clouds.yaml would look
like below and there is no need to have any logic in the
modules.

clouds:
  undercloud:
    auth: {}
    auth_type: none
    baremetal_api_version: '1'
    baremetal_endpoint_override: https://192.168.24.2:13385

Change-Id: Iacf16819ee98ed9d41abbe0e7f6a77f36e803de2
2021-07-01 09:52:27 +05:30

81 lines
2.5 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 cleaning 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
- raid_configuration
tasks:
- name: Set node_uuids_raid fact
set_fact:
node_uuids_raid: "{{ 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_raid | length)) |
ternary((node_uuids_raid | 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_raid | length) < 1
- name: Notice
debug:
msg: >-
Running raid config on the following nodes, {{ node_uuids_raid }}.
- name: Start baremetal raid configuration
os_baremetal_clean_node:
node_uuid: "{{ node_uuids_raid }}"
concurrency: "{{ runtime_concurrency }}"
raid_config: "{{ raid_configuration }}"
timeout: "{{ node_timeout }}"
clean_steps:
- interface: raid
step: delete_configuration
- interface: deploy
step: erase_devices_metadata
- interface: raid
step: create_configuration