2018-07-18 21:59:22 +08:00
|
|
|
---
|
2019-10-08 20:42:44 +08:00
|
|
|
- name: find device used for operating system
|
|
|
|
command: findmnt -v -n -T / -o SOURCE
|
|
|
|
changed_when: false
|
|
|
|
register: root_device
|
|
|
|
|
|
|
|
- name: resolve root_device
|
|
|
|
command: "readlink -f {{ root_device.stdout }}"
|
|
|
|
changed_when: false
|
|
|
|
register: _root_device
|
|
|
|
|
|
|
|
- name: set_fact root_device
|
|
|
|
set_fact:
|
|
|
|
root_device: "{{ _root_device.stdout }}"
|
|
|
|
|
|
|
|
- name: lvm_volumes variable's tasks related
|
|
|
|
when:
|
|
|
|
- lvm_volumes is defined
|
|
|
|
- lvm_volumes | length > 0
|
|
|
|
block:
|
|
|
|
- name: resolve devices in lvm_volumes
|
|
|
|
command: "readlink -f {{ item.data }}"
|
|
|
|
changed_when: false
|
|
|
|
register: _lvm_volumes_data_devices
|
|
|
|
with_items: "{{ lvm_volumes }}"
|
|
|
|
when:
|
|
|
|
- item.data_vg is undefined
|
|
|
|
|
|
|
|
- name: set_fact lvm_volumes_data_devices
|
|
|
|
set_fact:
|
|
|
|
lvm_volumes_data_devices: "{{ lvm_volumes_data_devices | default([]) + [item.stdout] }}"
|
|
|
|
with_items: "{{ _lvm_volumes_data_devices.results }}"
|
|
|
|
when:
|
|
|
|
- item.skipped is undefined
|
|
|
|
|
|
|
|
- name: devices variable's tasks related
|
|
|
|
when:
|
|
|
|
- devices is defined
|
|
|
|
- devices | length > 0
|
|
|
|
block:
|
|
|
|
- name: resolve devices in devices
|
|
|
|
command: "readlink -f {{ item }}"
|
|
|
|
changed_when: false
|
|
|
|
register: devices_resolved
|
|
|
|
with_items: "{{ devices }}"
|
|
|
|
|
|
|
|
- name: set_fact devices_resolved
|
|
|
|
set_fact:
|
|
|
|
_devices: "{{ _devices | default([]) + [item.stdout] }}"
|
|
|
|
with_items: "{{ devices_resolved.results }}"
|
|
|
|
|
|
|
|
- name: fail if root_device is passed in lvm_volumes or devices
|
|
|
|
fail:
|
|
|
|
msg: "{{ root_device }} found in either lvm_volumes or devices variable"
|
|
|
|
when: root_device in lvm_volumes_data_devices | default([]) or root_device in _devices | default([])
|
|
|
|
|
2019-10-01 15:34:14 +08:00
|
|
|
- name: check no gpt header is present when osd scenario is lvm/lvm-batch
|
2019-06-07 16:50:28 +08:00
|
|
|
block:
|
2019-07-17 21:55:12 +08:00
|
|
|
- name: read information about the devices
|
|
|
|
parted:
|
2019-10-01 15:34:14 +08:00
|
|
|
device: "{{ item.data if item.data_vg is undefined and lvm_volumes is defined else item if devices is defined else omit }}"
|
2019-07-17 21:55:12 +08:00
|
|
|
unit: MiB
|
|
|
|
register: parted_results
|
2019-10-01 15:34:14 +08:00
|
|
|
with_items: "{{ lvm_volumes | default(devices) }}"
|
|
|
|
when:
|
|
|
|
- inventory_hostname in groups.get(osd_group_name, [])
|
|
|
|
- (item.data is defined and item.data_vg is undefined) or devices is defined
|
2019-07-17 21:55:12 +08:00
|
|
|
|
|
|
|
- name: fail when gpt header found on osd devices
|
|
|
|
fail:
|
|
|
|
msg: "{{ item.disk.dev }} has gpt header, please remove it."
|
|
|
|
with_items: "{{ parted_results.results }}"
|
|
|
|
when:
|
2019-10-01 15:34:14 +08:00
|
|
|
- item.skipped is undefined
|
2019-07-17 21:55:12 +08:00
|
|
|
- item.disk.table == 'gpt'
|
|
|
|
- item.partitions | length == 0
|
|
|
|
|
2019-10-01 15:34:14 +08:00
|
|
|
- name: check devices are block devices
|
|
|
|
block:
|
2019-06-07 16:50:28 +08:00
|
|
|
- name: get devices information
|
|
|
|
parted:
|
|
|
|
device: "{{ item }}"
|
|
|
|
unit: MiB
|
|
|
|
register: devices_parted
|
|
|
|
failed_when: False
|
|
|
|
with_items: "{{ devices }}"
|
2018-07-18 21:59:22 +08:00
|
|
|
|
2019-06-07 16:50:28 +08:00
|
|
|
- name: fail if one of the devices is not a device
|
|
|
|
fail:
|
validate: improve message printed in check_devices.yml
The message prints the whole content of the registered variable in the
playbook, this is not needed and makes the message pretty unclear and
unreadable.
```
"msg": "{'_ansible_parsed': True, 'changed': False, '_ansible_no_log': False, u'err': u'Error: Could not stat device /dev/sdf - No such file or directory.\\n', 'item': u'/dev/sdf', '_ansible_item_result': True, u'failed': False, '_ansible_item_label': u'/dev/sdf', u'msg': u\"Error while getting device information with parted script: '/sbin/parted -s -m /dev/sdf -- unit 'MiB' print'\", u'rc': 1, u'invocation': {u'module_args': {u'part_start': u'0%', u'part_end': u'100%', u'name': None, u'align': u'optimal', u'number': None, u'label': u'msdos', u'state': u'info', u'part_type': u'primary', u'flags': None, u'device': u'/dev/sdf', u'unit': u'MiB'}}, 'failed_when_result': False, '_ansible_ignore_errors': None, u'out': u''} is not a block special file!"
```
Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=1719023
Signed-off-by: Guillaume Abrioux <gabrioux@redhat.com>
(cherry picked from commit e6dc3ebd8c8161e56c0a4a1fdb409272b9fd5342)
2019-07-10 21:08:39 +08:00
|
|
|
msg: "{{ item.item }} is not a block special file!"
|
2019-06-07 16:50:28 +08:00
|
|
|
when: item.rc is defined
|
|
|
|
with_items: "{{ devices_parted.results }}"
|