Fix error 601
Don't compare to literal True/False Change-Id: I671978ac95de03d80b059d42f188e9fc9aecb4b4
This commit is contained in:
parent
1d5f0bbdc7
commit
e4d0325b2f
@ -3,7 +3,6 @@ skip_list:
|
|||||||
- '208' # File permissions not mentioned
|
- '208' # File permissions not mentioned
|
||||||
- '301' # Commands should not change things if nothing needs doing
|
- '301' # Commands should not change things if nothing needs doing
|
||||||
- '502' # All tasks should be named
|
- '502' # All tasks should be named
|
||||||
- '601' # Don't compare to literal True/False
|
|
||||||
- '701' # meta/main.yml should contain relevant info
|
- '701' # meta/main.yml should contain relevant info
|
||||||
- '702' # Tags must contain lowercase letters and digits only
|
- '702' # Tags must contain lowercase letters and digits only
|
||||||
# NOTE(dtantsur): the following rules should likely stay excluded:
|
# NOTE(dtantsur): the following rules should likely stay excluded:
|
||||||
|
@ -7,5 +7,5 @@
|
|||||||
- role: ironic-enroll-dynamic
|
- role: ironic-enroll-dynamic
|
||||||
delegate_to: "{{ groups['target'][0] if groups['target'] is defined else 'localhost' }}"
|
delegate_to: "{{ groups['target'][0] if groups['target'] is defined else 'localhost' }}"
|
||||||
- role: ironic-inspect-node
|
- role: ironic-inspect-node
|
||||||
when: inspect_nodes | default('false') | bool == true
|
when: inspect_nodes | default('false') | bool
|
||||||
delegate_to: "{{ groups['target'][0] if groups['target'] is defined else 'localhost' }}"
|
delegate_to: "{{ groups['target'][0] if groups['target'] is defined else 'localhost' }}"
|
||||||
|
@ -26,5 +26,7 @@
|
|||||||
become: no
|
become: no
|
||||||
connection: local
|
connection: local
|
||||||
roles:
|
roles:
|
||||||
- { role: bifrost-configdrives-dynamic, when: provision_state == "available" and maintenance | bool != true }
|
- { role: bifrost-configdrives-dynamic,
|
||||||
- { role: bifrost-deploy-nodes-dynamic, when: provision_state == "available" and maintenance | bool != true }
|
when: provision_state == "available" and maintenance | bool }
|
||||||
|
- { role: bifrost-deploy-nodes-dynamic,
|
||||||
|
when: provision_state == "available" and maintenance | bool }
|
||||||
|
@ -38,9 +38,11 @@
|
|||||||
skip_items: []
|
skip_items: []
|
||||||
register: node_info
|
register: node_info
|
||||||
roles:
|
roles:
|
||||||
- { role: bifrost-unprovision-node-dynamic, when: (provision_state == "active"
|
- { role: bifrost-unprovision-node-dynamic,
|
||||||
or provision_state == "deploy failed"
|
when: (provision_state == "active"
|
||||||
or provision_state == "error") and maintenance | bool != true }
|
or provision_state == "deploy failed"
|
||||||
|
or provision_state == "error")
|
||||||
|
and (not maintenance | bool) }
|
||||||
post_tasks:
|
post_tasks:
|
||||||
- name: "Pull ironic facts until provision state available"
|
- name: "Pull ironic facts until provision state available"
|
||||||
os_ironic_node_info:
|
os_ironic_node_info:
|
||||||
@ -58,8 +60,10 @@
|
|||||||
become: no
|
become: no
|
||||||
connection: local
|
connection: local
|
||||||
roles:
|
roles:
|
||||||
- { role: bifrost-configdrives-dynamic, when: provision_state == "available" and maintenance | bool != true }
|
- { role: bifrost-configdrives-dynamic,
|
||||||
- { role: bifrost-deploy-nodes-dynamic, when: provision_state == "available" and maintenance | bool != true }
|
when: (provision_state == "available") and (not maintenance | bool) }
|
||||||
|
- { role: bifrost-deploy-nodes-dynamic,
|
||||||
|
when: (provision_state == "available") and (not maintenance | bool) }
|
||||||
post_tasks:
|
post_tasks:
|
||||||
- name: "Pull ironic facts until provision state active"
|
- name: "Pull ironic facts until provision state active"
|
||||||
os_ironic_node_info:
|
os_ironic_node_info:
|
||||||
|
@ -66,7 +66,7 @@
|
|||||||
|
|
||||||
- name: "Write network Debian style interface template"
|
- name: "Write network Debian style interface template"
|
||||||
template: src=interfaces.j2 dest={{ variable_configdrive_location.path }}/{{ uuid }}/openstack/content/0000
|
template: src=interfaces.j2 dest={{ variable_configdrive_location.path }}/{{ uuid }}/openstack/content/0000
|
||||||
when: write_interfaces_file | bool == true
|
when: write_interfaces_file | bool
|
||||||
|
|
||||||
- name: "Check if mkisofs is available"
|
- name: "Check if mkisofs is available"
|
||||||
command: mkisofs --help
|
command: mkisofs --help
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
- name: "Defined ssh_public_key_path - Error if ssh_public_key_path is not valid"
|
- name: "Defined ssh_public_key_path - Error if ssh_public_key_path is not valid"
|
||||||
fail:
|
fail:
|
||||||
msg: "ssh_public_key_path is not valid."
|
msg: "ssh_public_key_path is not valid."
|
||||||
when: test_ssh_public_key_path.stat.exists == false
|
when: not test_ssh_public_key_path.stat.exists | bool
|
||||||
delegate_to: localhost
|
delegate_to: localhost
|
||||||
|
|
||||||
- name: "Defined ssh_public_key_path - Read SSH public key in"
|
- name: "Defined ssh_public_key_path - Read SSH public key in"
|
||||||
|
@ -18,4 +18,4 @@
|
|||||||
register: test_image_present
|
register: test_image_present
|
||||||
- name: "Create bootable image"
|
- name: "Create bootable image"
|
||||||
include: create_bootable_image.yml
|
include: create_bootable_image.yml
|
||||||
when: test_image_present.stat.exists == true
|
when: test_image_present.stat.exists | bool
|
||||||
|
@ -25,37 +25,39 @@
|
|||||||
- name: "Test if image is present - {{ dib_imagename }}.{{ dib_imagetype | default('qcow2') }}"
|
- name: "Test if image is present - {{ dib_imagename }}.{{ dib_imagetype | default('qcow2') }}"
|
||||||
stat: path={{ dib_imagename }}.{{ dib_imagetype | default('qcow2') }}
|
stat: path={{ dib_imagename }}.{{ dib_imagetype | default('qcow2') }}
|
||||||
register: test_image_dib_present
|
register: test_image_dib_present
|
||||||
when: test_image_present.stat.exists == false
|
when: not test_image_present.stat.exists
|
||||||
# Note(TheJulia): We need to explicitly test for initramfs in the case
|
# Note(TheJulia): We need to explicitly test for initramfs in the case
|
||||||
# that the ironic-python-agent-ramdisk element is used to build the image.
|
# that the ironic-python-agent-ramdisk element is used to build the image.
|
||||||
- name: "Test if image is present - {{ dib_imagename }}.initramfs"
|
- name: "Test if image is present - {{ dib_imagename }}.initramfs"
|
||||||
stat: path={{ dib_imagename }}.initramfs
|
stat: path={{ dib_imagename }}.initramfs
|
||||||
register: test_image_initramfs_present
|
register: test_image_initramfs_present
|
||||||
when: test_image_present.stat.exists == false and test_image_dib_present.stat.exists == false
|
when:
|
||||||
|
- not test_image_present.stat.exists
|
||||||
|
- not test_image_dib_present.stat.exists
|
||||||
- name: "Build tracing (-x) option for disk-image-create"
|
- name: "Build tracing (-x) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_trace_arg: "-x"
|
dib_trace_arg: "-x"
|
||||||
when: dib_trace == true
|
when: dib_trace | bool
|
||||||
- name: "Build uncompressed (-u) option for disk-image-create"
|
- name: "Build uncompressed (-u) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_uncompressed_arg: "-u"
|
dib_uncompressed_arg: "-u"
|
||||||
when: dib_uncompressed == true
|
when: dib_uncompressed | bool
|
||||||
- name: "Build clear environment (-c) option for disk-image-create"
|
- name: "Build clear environment (-c) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_clearenv_arg: "-c"
|
dib_clearenv_arg: "-c"
|
||||||
when: dib_clearenv == true
|
when: dib_clearenv | bool
|
||||||
- name: "Build no tmpfs (--no-tmpfs) option for disk-image-create"
|
- name: "Build no tmpfs (--no-tmpfs) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_notmpfs_arg: "--no-tmpfs"
|
dib_notmpfs_arg: "--no-tmpfs"
|
||||||
when: dib_notmpfs == true
|
when: dib_notmpfs | bool
|
||||||
- name: "Build offline (--offline) option for disk-image-create"
|
- name: "Build offline (--offline) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_offline_arg: "--offline"
|
dib_offline_arg: "--offline"
|
||||||
when: dib_offline == true
|
when: dib_offline | bool
|
||||||
- name: "Build skip default base element (-n) option for disk-image-create"
|
- name: "Build skip default base element (-n) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_skipbase_arg: "-n"
|
dib_skipbase_arg: "-n"
|
||||||
when: dib_skipbase == true
|
when: dib_skipbase | bool
|
||||||
- name: "Build architecture (-a) option for disk-image-create"
|
- name: "Build architecture (-a) option for disk-image-create"
|
||||||
set_fact:
|
set_fact:
|
||||||
dib_arch_arg: "-a {{ dib_arch }}"
|
dib_arch_arg: "-a {{ dib_arch }}"
|
||||||
@ -187,11 +189,11 @@
|
|||||||
package:
|
package:
|
||||||
name: debootstrap
|
name: debootstrap
|
||||||
state: present
|
state: present
|
||||||
when: >
|
when:
|
||||||
test_image_present.stat.exists == false
|
- not test_image_present.stat.exists
|
||||||
and test_image_dib_present.stat.exists == false
|
- not test_image_dib_present.stat.exists
|
||||||
and test_image_initramfs_present.stat.exists == false
|
- not test_image_initramfs_present.stat.exists
|
||||||
and ("debian" in dib_os_element or "ubuntu" in dib_os_element)
|
- ("debian" in dib_os_element or "ubuntu" in dib_os_element)
|
||||||
- name: "Initiate image build"
|
- name: "Initiate image build"
|
||||||
command: disk-image-create {{ dib_arglist }}
|
command: disk-image-create {{ dib_arglist }}
|
||||||
environment: "{{ dib_env_vars_final | combine(bifrost_venv_env) }}"
|
environment: "{{ dib_env_vars_final | combine(bifrost_venv_env) }}"
|
||||||
|
@ -79,7 +79,7 @@
|
|||||||
version: "{{ reqs_git_branch }}"
|
version: "{{ reqs_git_branch }}"
|
||||||
update: "{{ update_repos | bool }}"
|
update: "{{ update_repos | bool }}"
|
||||||
clone: yes
|
clone: yes
|
||||||
when: copy_from_local_path | bool == false
|
when: not copy_from_local_path | bool
|
||||||
|
|
||||||
- name: copy requirements from local path
|
- name: copy requirements from local path
|
||||||
command: cp -a {{ reqs_git_url }} {{ reqs_git_folder }} creates={{ reqs_git_folder }}
|
command: cp -a {{ reqs_git_url }} {{ reqs_git_folder }} creates={{ reqs_git_folder }}
|
||||||
|
@ -57,9 +57,9 @@
|
|||||||
|
|
||||||
- name: "Place sgabios.bin"
|
- name: "Place sgabios.bin"
|
||||||
command: cp /usr/share/misc/sgabios.bin /usr/share/qemu/sgabios.bin
|
command: cp /usr/share/misc/sgabios.bin /usr/share/qemu/sgabios.bin
|
||||||
when: >
|
when:
|
||||||
test_sgabios_qemu == false and
|
- not test_sgabios_qemu | bool
|
||||||
test_sgabios_misc == true
|
- test_sgabios_misc | bool
|
||||||
|
|
||||||
# NOTE(TheJulia): In order to prevent conflicts, stop
|
# NOTE(TheJulia): In order to prevent conflicts, stop
|
||||||
# dnsmasq to prevent conflicts with libvirt restarting.
|
# dnsmasq to prevent conflicts with libvirt restarting.
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
owner: root
|
owner: root
|
||||||
group: root
|
group: root
|
||||||
mode: 0644
|
mode: 0644
|
||||||
when: inventory_dhcp | bool == true
|
when: inventory_dhcp | bool
|
||||||
become: yes
|
become: yes
|
||||||
|
|
||||||
- name: "Setup DNS address for nodes."
|
- name: "Setup DNS address for nodes."
|
||||||
@ -41,7 +41,7 @@
|
|||||||
owner: root
|
owner: root
|
||||||
group: root
|
group: root
|
||||||
mode: 0644
|
mode: 0644
|
||||||
when: inventory_dns | bool == true
|
when: inventory_dns | bool
|
||||||
become: yes
|
become: yes
|
||||||
|
|
||||||
- name: "Restarting dnsmasq"
|
- name: "Restarting dnsmasq"
|
||||||
@ -49,7 +49,7 @@
|
|||||||
name: dnsmasq
|
name: dnsmasq
|
||||||
state: restarted
|
state: restarted
|
||||||
become: yes
|
become: yes
|
||||||
when: (inventory_dhcp | bool == true) or (inventory_dns | bool == true)
|
when: inventory_dhcp | bool or inventory_dns | bool
|
||||||
|
|
||||||
- name: "Deploy to hardware - Using custom instance_info."
|
- name: "Deploy to hardware - Using custom instance_info."
|
||||||
openstack.cloud.baremetal_node_action:
|
openstack.cloud.baremetal_node_action:
|
||||||
@ -76,7 +76,9 @@
|
|||||||
|
|
||||||
- name: "Error if deploy_image is not present, and instance_info is not defined"
|
- name: "Error if deploy_image is not present, and instance_info is not defined"
|
||||||
fail: msg="The user-defined deploy_image, which is the image to be written to the remote node(s) upon deployment, was not found. Cannot proceed."
|
fail: msg="The user-defined deploy_image, which is the image to be written to the remote node(s) upon deployment, was not found. Cannot proceed."
|
||||||
when: instance_info is not defined and test_deploy_image.stat.exists | bool == false
|
when:
|
||||||
|
- instance_info is not defined
|
||||||
|
- not test_deploy_image.stat.exists
|
||||||
|
|
||||||
- name: "Deploy to hardware - bifrost default"
|
- name: "Deploy to hardware - bifrost default"
|
||||||
openstack.cloud.baremetal_node_action:
|
openstack.cloud.baremetal_node_action:
|
||||||
|
@ -18,9 +18,9 @@
|
|||||||
msg: >
|
msg: >
|
||||||
noauth_mode and enable_keystone are mutually exclusive options.
|
noauth_mode and enable_keystone are mutually exclusive options.
|
||||||
Please set one to "false".
|
Please set one to "false".
|
||||||
when: >
|
when:
|
||||||
noauth_mode | bool == true and enable_keystone is defined and
|
- noauth_mode | bool
|
||||||
enable_keystone | bool == true
|
- enable_keystone | bool
|
||||||
|
|
||||||
- block:
|
- block:
|
||||||
- name: "Ask systemd to reload configuration"
|
- name: "Ask systemd to reload configuration"
|
||||||
@ -161,7 +161,8 @@
|
|||||||
|
|
||||||
- name: "Populate keystone for Bifrost"
|
- name: "Populate keystone for Bifrost"
|
||||||
include: keystone_setup.yml
|
include: keystone_setup.yml
|
||||||
when: enable_keystone is defined and enable_keystone | bool == true
|
when:
|
||||||
|
- enable_keystone | bool
|
||||||
|
|
||||||
# NOTE(pas-ha) needed to e.g. pick up new interfaces after libvirt install
|
# NOTE(pas-ha) needed to e.g. pick up new interfaces after libvirt install
|
||||||
- name: "Refresh facts"
|
- name: "Refresh facts"
|
||||||
@ -186,16 +187,16 @@
|
|||||||
- name: "Create ironic DB Schema"
|
- name: "Create ironic DB Schema"
|
||||||
command: ironic-dbsync --config-file /etc/ironic/ironic.conf create_schema
|
command: ironic-dbsync --config-file /etc/ironic/ironic.conf create_schema
|
||||||
environment: "{{ bifrost_venv_env }}"
|
environment: "{{ bifrost_venv_env }}"
|
||||||
when: >
|
when:
|
||||||
ironic.database.host == 'localhost' and
|
- ironic.database.host == 'localhost'
|
||||||
test_created_db.changed | bool == true
|
- test_created_db.changed | bool
|
||||||
|
|
||||||
- name: "Upgrade ironic DB Schema"
|
- name: "Upgrade ironic DB Schema"
|
||||||
command: ironic-dbsync --config-file /etc/ironic/ironic.conf upgrade
|
command: ironic-dbsync --config-file /etc/ironic/ironic.conf upgrade
|
||||||
environment: "{{ bifrost_venv_env }}"
|
environment: "{{ bifrost_venv_env }}"
|
||||||
when: >
|
when: >
|
||||||
ironic.database.host != 'localhost' or
|
ironic.database.host != 'localhost' or
|
||||||
test_created_db.changed | bool == false
|
not test_created_db.changed | bool
|
||||||
|
|
||||||
- name: "Create service folder"
|
- name: "Create service folder"
|
||||||
file:
|
file:
|
||||||
@ -205,7 +206,7 @@
|
|||||||
|
|
||||||
- name: "Install ironic-inspector to permit use of inspection interface"
|
- name: "Install ironic-inspector to permit use of inspection interface"
|
||||||
include: inspector_bootstrap.yml
|
include: inspector_bootstrap.yml
|
||||||
when: enable_inspector | bool == true
|
when: enable_inspector | bool
|
||||||
|
|
||||||
- name: "Get ironic-api & ironic-conductor install location"
|
- name: "Get ironic-api & ironic-conductor install location"
|
||||||
shell: echo $(dirname $(which ironic-api))
|
shell: echo $(dirname $(which ironic-api))
|
||||||
@ -249,7 +250,7 @@
|
|||||||
owner: "root"
|
owner: "root"
|
||||||
group: "root"
|
group: "root"
|
||||||
mode: 0755
|
mode: 0755
|
||||||
when: inventory_dhcp | bool == true
|
when: inventory_dhcp | bool
|
||||||
- name: "Setup Inventory DHCP Hosts Directory"
|
- name: "Setup Inventory DHCP Hosts Directory"
|
||||||
file:
|
file:
|
||||||
path: "/etc/dnsmasq.d/bifrost.dhcp-hosts.d"
|
path: "/etc/dnsmasq.d/bifrost.dhcp-hosts.d"
|
||||||
@ -257,19 +258,19 @@
|
|||||||
owner: "root"
|
owner: "root"
|
||||||
group: "root"
|
group: "root"
|
||||||
mode: 0755
|
mode: 0755
|
||||||
when: inventory_dhcp | bool == true
|
when: inventory_dhcp | bool
|
||||||
- name: "Retrieve interface IP informations"
|
- name: "Retrieve interface IP informations"
|
||||||
set_fact:
|
set_fact:
|
||||||
itf_infos: "{{ internal_interface }}"
|
itf_infos: "{{ internal_interface }}"
|
||||||
dhcp_netaddr: "{{ dhcp_pool_start }}/{{ dhcp_static_mask }}"
|
dhcp_netaddr: "{{ dhcp_pool_start }}/{{ dhcp_static_mask }}"
|
||||||
when: include_dhcp_server | bool == true
|
when: include_dhcp_server | bool
|
||||||
- name: "Compute interface and DHCP network informations"
|
- name: "Compute interface and DHCP network informations"
|
||||||
set_fact:
|
set_fact:
|
||||||
itf_netaddr1: "{{ itf_infos['address'] }}/{{ itf_infos['netmask'] }}"
|
itf_netaddr1: "{{ itf_infos['address'] }}/{{ itf_infos['netmask'] }}"
|
||||||
itf_netaddr2: "{{ itf_infos['network'] }}/{{ itf_infos['netmask'] }}"
|
itf_netaddr2: "{{ itf_infos['network'] }}/{{ itf_infos['netmask'] }}"
|
||||||
itf_broadcast: "{{ itf_infos['broadcast'] }}/{{ itf_infos['netmask'] }}"
|
itf_broadcast: "{{ itf_infos['broadcast'] }}/{{ itf_infos['netmask'] }}"
|
||||||
dhcp_netaddr: "{{ dhcp_netaddr | ipaddr('network') }}/{{ dhcp_static_mask }}"
|
dhcp_netaddr: "{{ dhcp_netaddr | ipaddr('network') }}/{{ dhcp_static_mask }}"
|
||||||
when: include_dhcp_server | bool == true
|
when: include_dhcp_server | bool
|
||||||
- name: "Validate interface network addresses"
|
- name: "Validate interface network addresses"
|
||||||
fail:
|
fail:
|
||||||
msg: >
|
msg: >
|
||||||
@ -304,7 +305,7 @@
|
|||||||
dhcp_end_ip: "{{ dhcp_pool_end.split('.')[-1] }}"
|
dhcp_end_ip: "{{ dhcp_pool_end.split('.')[-1] }}"
|
||||||
dhcp_netaddr: "{{ itf_netaddr1 | ipaddr('network') }}"
|
dhcp_netaddr: "{{ itf_netaddr1 | ipaddr('network') }}"
|
||||||
when:
|
when:
|
||||||
- include_dhcp_server | bool == true
|
- include_dhcp_server | bool
|
||||||
- itf_netaddr2 | ipaddr('network') != dhcp_netaddr | ipaddr('network')
|
- itf_netaddr2 | ipaddr('network') != dhcp_netaddr | ipaddr('network')
|
||||||
# Note(olivierbourdon38): we could do much more complex network
|
# Note(olivierbourdon38): we could do much more complex network
|
||||||
# computation to derive exact (or way closer to exact) range for
|
# computation to derive exact (or way closer to exact) range for
|
||||||
@ -314,28 +315,30 @@
|
|||||||
dhcp_pool_start: "{{ '.'.join(dhcp_netaddr.split('.')[0:-1]) }}.{{ dhcp_start_ip }}"
|
dhcp_pool_start: "{{ '.'.join(dhcp_netaddr.split('.')[0:-1]) }}.{{ dhcp_start_ip }}"
|
||||||
dhcp_pool_end: "{{ '.'.join(dhcp_netaddr.split('.')[0:-1]) }}.{{ dhcp_end_ip }}"
|
dhcp_pool_end: "{{ '.'.join(dhcp_netaddr.split('.')[0:-1]) }}.{{ dhcp_end_ip }}"
|
||||||
when:
|
when:
|
||||||
- include_dhcp_server | bool == true
|
- include_dhcp_server | bool
|
||||||
- itf_netaddr2 | ipaddr('network') != dhcp_netaddr | ipaddr('network')
|
- itf_netaddr2 | ipaddr('network') != dhcp_netaddr | ipaddr('network')
|
||||||
- name: "Deploy dnsmasq configuration file"
|
- name: "Deploy dnsmasq configuration file"
|
||||||
template: src=dnsmasq.conf.j2 dest=/etc/dnsmasq.conf
|
template: src=dnsmasq.conf.j2 dest=/etc/dnsmasq.conf
|
||||||
when: include_dhcp_server | bool == true
|
when: include_dhcp_server | bool
|
||||||
# NOTE(Shrews) When testing, we want to use our custom dnsmasq.conf file,
|
# NOTE(Shrews) When testing, we want to use our custom dnsmasq.conf file,
|
||||||
# not the one supplied by libvirt.
|
# not the one supplied by libvirt.
|
||||||
- name: "Look for libvirt dnsmasq config"
|
- name: "Look for libvirt dnsmasq config"
|
||||||
stat: path=/etc/dnsmasq.d/libvirt-bin
|
stat: path=/etc/dnsmasq.d/libvirt-bin
|
||||||
register: test_libvirt_dnsmasq
|
register: test_libvirt_dnsmasq
|
||||||
when: include_dhcp_server | bool == true
|
when: include_dhcp_server | bool
|
||||||
- name: "Disable libvirt dnsmasq config"
|
- name: "Disable libvirt dnsmasq config"
|
||||||
command: mv /etc/dnsmasq.d/libvirt-bin /etc/dnsmasq.d/libvirt-bin~
|
command: mv /etc/dnsmasq.d/libvirt-bin /etc/dnsmasq.d/libvirt-bin~
|
||||||
when: >
|
when:
|
||||||
include_dhcp_server | bool == true and
|
- include_dhcp_server | bool
|
||||||
test_libvirt_dnsmasq.stat.exists | bool == true and
|
- test_libvirt_dnsmasq.stat.exists
|
||||||
testing | bool == true
|
- testing | bool
|
||||||
- name: "Deploy nginx configuration file for serving HTTP requests"
|
- name: "Deploy nginx configuration file for serving HTTP requests"
|
||||||
template: src=nginx.conf.j2 dest=/etc/nginx/nginx.conf
|
template: src=nginx.conf.j2 dest=/etc/nginx/nginx.conf
|
||||||
- name: "Download Ironic Python Agent kernel & image"
|
- name: "Download Ironic Python Agent kernel & image"
|
||||||
include: download_ipa_image.yml
|
include: download_ipa_image.yml
|
||||||
when: create_ipa_image | bool == false and download_ipa | bool == true
|
when:
|
||||||
|
- not create_ipa_image | bool
|
||||||
|
- download_ipa | bool
|
||||||
- name: "Download cirros to use for deployment if requested"
|
- name: "Download cirros to use for deployment if requested"
|
||||||
get_url:
|
get_url:
|
||||||
url: "{{ cirros_deploy_image_upstream_url }}"
|
url: "{{ cirros_deploy_image_upstream_url }}"
|
||||||
@ -343,7 +346,7 @@
|
|||||||
owner: ironic
|
owner: ironic
|
||||||
group: ironic
|
group: ironic
|
||||||
mode: 0644
|
mode: 0644
|
||||||
when: use_cirros | bool == true
|
when: use_cirros | bool
|
||||||
- name: "Create a checksum file for cirros"
|
- name: "Create a checksum file for cirros"
|
||||||
shell: md5sum {{ deploy_image_filename }} > {{ deploy_image_filename }}.CHECKSUMS
|
shell: md5sum {{ deploy_image_filename }} > {{ deploy_image_filename }}.CHECKSUMS
|
||||||
args:
|
args:
|
||||||
|
@ -42,7 +42,7 @@
|
|||||||
|
|
||||||
- name: "Download ipxe files if asked"
|
- name: "Download ipxe files if asked"
|
||||||
include: get_ipxe.yml
|
include: get_ipxe.yml
|
||||||
when: download_ipxe | bool == true
|
when: download_ipxe | bool
|
||||||
|
|
||||||
- name: "Copy iPXE image into place"
|
- name: "Copy iPXE image into place"
|
||||||
copy:
|
copy:
|
||||||
@ -88,7 +88,7 @@
|
|||||||
at the {{ ipxe_dir }} location. Please place this file or consider
|
at the {{ ipxe_dir }} location. Please place this file or consider
|
||||||
re-running with download_ipxe set to a value of true.
|
re-running with download_ipxe set to a value of true.
|
||||||
when:
|
when:
|
||||||
- test_ipxe_efi_binary_path.stat.exists | bool == false
|
- not test_ipxe_efi_binary_path.stat.exists
|
||||||
|
|
||||||
- name: "Copy iPXE EFI image into {{ http_boot_folder }}/"
|
- name: "Copy iPXE EFI image into {{ http_boot_folder }}/"
|
||||||
copy:
|
copy:
|
||||||
@ -108,7 +108,7 @@
|
|||||||
mode: 0644
|
mode: 0644
|
||||||
remote_src: true
|
remote_src: true
|
||||||
|
|
||||||
when: enable_uefi_ipxe | bool == true
|
when: enable_uefi_ipxe | bool
|
||||||
|
|
||||||
# Similar logic to below can be utilized to retrieve files
|
# Similar logic to below can be utilized to retrieve files
|
||||||
- name: "Determine if folder exists, else create and populate folder."
|
- name: "Determine if folder exists, else create and populate folder."
|
||||||
@ -117,7 +117,7 @@
|
|||||||
|
|
||||||
- name: "Create master_images folder"
|
- name: "Create master_images folder"
|
||||||
file: name="{{ ironic_tftp_master_path }}" state=directory owner=ironic group=ironic
|
file: name="{{ ironic_tftp_master_path }}" state=directory owner=ironic group=ironic
|
||||||
when: test_master_images.stat.exists == false
|
when: not test_master_images.stat.exists
|
||||||
|
|
||||||
# TODO(TheJulia): The pxelinux folder is statically coded in ironic.
|
# TODO(TheJulia): The pxelinux folder is statically coded in ironic.
|
||||||
# For now, we need to use it, but we can patch that.
|
# For now, we need to use it, but we can patch that.
|
||||||
@ -128,4 +128,4 @@
|
|||||||
owner: ironic
|
owner: ironic
|
||||||
group: ironic
|
group: ironic
|
||||||
mode: 0644
|
mode: 0644
|
||||||
when: enable_inspector | bool == true
|
when: enable_inspector | bool
|
||||||
|
@ -77,7 +77,7 @@
|
|||||||
delay: 10
|
delay: 10
|
||||||
when:
|
when:
|
||||||
- update_ipa | bool or
|
- update_ipa | bool or
|
||||||
test_ipa_kernel_present.stat.exists == false
|
not test_ipa_kernel_present.stat.exists
|
||||||
|
|
||||||
- name: "Test if IPA image is present"
|
- name: "Test if IPA image is present"
|
||||||
stat: path={{ ipa_ramdisk }}
|
stat: path={{ ipa_ramdisk }}
|
||||||
@ -141,4 +141,4 @@
|
|||||||
delay: 10
|
delay: 10
|
||||||
when:
|
when:
|
||||||
- update_ipa | bool or
|
- update_ipa | bool or
|
||||||
test_ipa_image_present.stat.exists == false
|
not test_ipa_image_present.stat.exists
|
||||||
|
@ -51,4 +51,4 @@
|
|||||||
delay: 10
|
delay: 10
|
||||||
loop:
|
loop:
|
||||||
- "{{ ipxe_efi_binary }}"
|
- "{{ ipxe_efi_binary }}"
|
||||||
when: enable_uefi_ipxe | bool == true
|
when: enable_uefi_ipxe | bool
|
||||||
|
@ -94,7 +94,7 @@
|
|||||||
|
|
||||||
- name: "Populate keystone for ironic-inspector "
|
- name: "Populate keystone for ironic-inspector "
|
||||||
include: keystone_setup_inspector.yml
|
include: keystone_setup_inspector.yml
|
||||||
when: enable_keystone is defined and enable_keystone | bool == true
|
when: enable_keystone | bool
|
||||||
|
|
||||||
- name: "Inspector - Place Configuration"
|
- name: "Inspector - Place Configuration"
|
||||||
template:
|
template:
|
||||||
|
@ -44,7 +44,7 @@
|
|||||||
package: ironic-python-agent-builder
|
package: ironic-python-agent-builder
|
||||||
sourcedir: "{{ ipa_builder_git_folder }}"
|
sourcedir: "{{ ipa_builder_git_folder }}"
|
||||||
source_install: true
|
source_install: true
|
||||||
when: install_dib | bool == true
|
when: install_dib | bool
|
||||||
|
|
||||||
# NOTE(mgoddard): IPA-builder has a dependency on diskimage-builder. Install
|
# NOTE(mgoddard): IPA-builder has a dependency on diskimage-builder. Install
|
||||||
# DIB last to ensure it is installed from source rather than PyPI.
|
# DIB last to ensure it is installed from source rather than PyPI.
|
||||||
@ -55,7 +55,7 @@
|
|||||||
package: diskimage-builder
|
package: diskimage-builder
|
||||||
sourcedir: "{{ dib_git_folder }}"
|
sourcedir: "{{ dib_git_folder }}"
|
||||||
source_install: true
|
source_install: true
|
||||||
when: install_dib | bool == true
|
when: install_dib | bool
|
||||||
|
|
||||||
- name: "sushy - Install"
|
- name: "sushy - Install"
|
||||||
include_role:
|
include_role:
|
||||||
@ -106,11 +106,11 @@
|
|||||||
|
|
||||||
- name: "Install ironic-inspector to permit use of inspection interface"
|
- name: "Install ironic-inspector to permit use of inspection interface"
|
||||||
include_tasks: inspector_install.yml
|
include_tasks: inspector_install.yml
|
||||||
when: enable_inspector | bool == true
|
when: enable_inspector | bool
|
||||||
|
|
||||||
- name: "Install ironic-staging-drivers"
|
- name: "Install ironic-staging-drivers"
|
||||||
include_tasks: staging_install.yml
|
include_tasks: staging_install.yml
|
||||||
when: staging_drivers_include | bool == true
|
when: staging_drivers_include | bool
|
||||||
|
|
||||||
- name: "Install openstacksdk"
|
- name: "Install openstacksdk"
|
||||||
include_role:
|
include_role:
|
||||||
|
@ -58,19 +58,19 @@
|
|||||||
|
|
||||||
- name: "Install Ironic deps"
|
- name: "Install Ironic deps"
|
||||||
include: install.yml
|
include: install.yml
|
||||||
when: skip_package_install | bool != True
|
when: not skip_package_install | bool
|
||||||
|
|
||||||
- name: "Bootstrap Ironic"
|
- name: "Bootstrap Ironic"
|
||||||
include: bootstrap.yml
|
include: bootstrap.yml
|
||||||
when: skip_bootstrap | bool != True
|
when: not skip_bootstrap | bool
|
||||||
|
|
||||||
- name: "Start Ironic services"
|
- name: "Start Ironic services"
|
||||||
include: start.yml
|
include: start.yml
|
||||||
when: skip_start | bool != True
|
when: not skip_start | bool
|
||||||
|
|
||||||
- name: "Perform online data migrations"
|
- name: "Perform online data migrations"
|
||||||
include: migrations.yml
|
include: migrations.yml
|
||||||
when: skip_migrations | bool != True
|
when: not skip_migrations | bool
|
||||||
|
|
||||||
- name: "Validate deployment"
|
- name: "Validate deployment"
|
||||||
include: validate.yml
|
include: validate.yml
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
- name: "Defined ssh_private_key_path - Error if ssh_private_key_path is not valid"
|
- name: "Defined ssh_private_key_path - Error if ssh_private_key_path is not valid"
|
||||||
fail:
|
fail:
|
||||||
msg: "ssh_private_key_path is not valid."
|
msg: "ssh_private_key_path is not valid."
|
||||||
when: test_ssh_private_key_path.stat.exists == false
|
when: not test_ssh_private_key_path.stat.exists
|
||||||
delegate_to: localhost
|
delegate_to: localhost
|
||||||
|
|
||||||
- name: "Defined ssh_private_key_path - Read SSH private key in"
|
- name: "Defined ssh_private_key_path - Read SSH private key in"
|
||||||
|
@ -33,7 +33,7 @@
|
|||||||
|
|
||||||
- name: "start ironic-inspector"
|
- name: "start ironic-inspector"
|
||||||
include: inspector_start.yml
|
include: inspector_start.yml
|
||||||
when: enable_inspector | bool == true
|
when: enable_inspector | bool
|
||||||
|
|
||||||
- name: "Start ironic-conductor"
|
- name: "Start ironic-conductor"
|
||||||
service: name=ironic-conductor state=started enabled=yes
|
service: name=ironic-conductor state=started enabled=yes
|
||||||
@ -62,7 +62,7 @@
|
|||||||
service: name={{ item }} state=restarted enabled=yes
|
service: name={{ item }} state=restarted enabled=yes
|
||||||
loop:
|
loop:
|
||||||
- dnsmasq
|
- dnsmasq
|
||||||
when: include_dhcp_server | bool == true
|
when: include_dhcp_server | bool
|
||||||
|
|
||||||
- name: "Send services a reload signal"
|
- name: "Send services a reload signal"
|
||||||
service: name={{ item }} state=reloaded
|
service: name={{ item }} state=reloaded
|
||||||
@ -72,4 +72,4 @@
|
|||||||
|
|
||||||
- name: "Send services a force-reload signal"
|
- name: "Send services a force-reload signal"
|
||||||
service: name=dnsmasq state=restarted
|
service: name=dnsmasq state=restarted
|
||||||
when: include_dhcp_server | bool == true
|
when: include_dhcp_server | bool
|
||||||
|
@ -140,10 +140,10 @@
|
|||||||
--bootstrap-internal-url="{{ keystone.bootstrap.internal_url | default(keystone_private_url) | default(keystone_api_url) }}"
|
--bootstrap-internal-url="{{ keystone.bootstrap.internal_url | default(keystone_private_url) | default(keystone_api_url) }}"
|
||||||
--bootstrap-region-id="{{ keystone.bootstrap.region_name }}"
|
--bootstrap-region-id="{{ keystone.bootstrap.region_name }}"
|
||||||
environment: "{{ bifrost_venv_env }}"
|
environment: "{{ bifrost_venv_env }}"
|
||||||
when: >
|
when:
|
||||||
test_created_keystone_db.changed | bool == true and
|
- test_created_keystone_db.changed
|
||||||
keystone.bootstrap.enabled | bool == true and
|
- keystone.bootstrap.enabled | bool
|
||||||
keystone.database.host == 'localhost'
|
- keystone.database.host == 'localhost'
|
||||||
|
|
||||||
- name: "Reserve keystone admin port"
|
- name: "Reserve keystone admin port"
|
||||||
sysctl:
|
sysctl:
|
||||||
|
@ -35,15 +35,21 @@
|
|||||||
|
|
||||||
- name: "Install Keystone"
|
- name: "Install Keystone"
|
||||||
include: install.yml
|
include: install.yml
|
||||||
when: enable_keystone is defined and enable_keystone |bool == True and skip_package_install | bool != True
|
when:
|
||||||
|
- enable_keystone | bool
|
||||||
|
- not skip_package_install | bool
|
||||||
|
|
||||||
- name: "Bootstrap Keystone"
|
- name: "Bootstrap Keystone"
|
||||||
include: bootstrap.yml
|
include: bootstrap.yml
|
||||||
when: enable_keystone is defined and enable_keystone |bool == True and skip_bootstrap | bool != True
|
when:
|
||||||
|
- enable_keystone | bool
|
||||||
|
- not skip_bootstrap | bool
|
||||||
|
|
||||||
- name: "Start Keystone services"
|
- name: "Start Keystone services"
|
||||||
include: start.yml
|
include: start.yml
|
||||||
when: enable_keystone is defined and enable_keystone |bool == True and skip_start | bool != True
|
when:
|
||||||
|
- enable_keystone | bool
|
||||||
|
- not skip_start | bool
|
||||||
|
|
||||||
- name: "Change the bootstrap password from the static value on upgrade"
|
- name: "Change the bootstrap password from the static value on upgrade"
|
||||||
os_user:
|
os_user:
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
- upper_constraints_file | length > 0
|
- upper_constraints_file | length > 0
|
||||||
# NOTE(dtantsur): constraining does not work correctly correctly with
|
# NOTE(dtantsur): constraining does not work correctly correctly with
|
||||||
# source installation if the package itself is in constraints.
|
# source installation if the package itself is in constraints.
|
||||||
- source_install | bool == false
|
- not source_install | bool
|
||||||
|
|
||||||
- name: "Install {{ package }} package from pip using virtualenv"
|
- name: "Install {{ package }} package from pip using virtualenv"
|
||||||
pip:
|
pip:
|
||||||
|
@ -30,9 +30,13 @@
|
|||||||
update: "{{ update_repos | bool }}"
|
update: "{{ update_repos | bool }}"
|
||||||
clone: yes
|
clone: yes
|
||||||
loop: "{{ bifrost_install_sources }}"
|
loop: "{{ bifrost_install_sources }}"
|
||||||
when: copy_from_local_path | bool == false and item.source_install | default(true) | bool
|
when:
|
||||||
|
- not copy_from_local_path | bool
|
||||||
|
- item.source_install | default(true) | bool
|
||||||
|
|
||||||
- name: "Copy from local path"
|
- name: "Copy from local path"
|
||||||
command: cp -a {{ item.git_url }} {{ item.git_folder }} creates={{ item.git_folder }}
|
command: cp -a {{ item.git_url }} {{ item.git_folder }} creates={{ item.git_folder }}
|
||||||
loop: "{{ bifrost_install_sources }}"
|
loop: "{{ bifrost_install_sources }}"
|
||||||
when: copy_from_local_path | bool == true and item.source_install | default(true) | bool
|
when:
|
||||||
|
- copy_from_local_path | bool
|
||||||
|
- item.source_install | default(true) | bool
|
||||||
|
@ -36,19 +36,21 @@
|
|||||||
when: ipv4_address is defined
|
when: ipv4_address is defined
|
||||||
- name: "Pause before asking for keyscan, to avoid races"
|
- name: "Pause before asking for keyscan, to avoid races"
|
||||||
pause: minutes=3
|
pause: minutes=3
|
||||||
when: multinode_testing | bool == true
|
when: multinode_testing | bool
|
||||||
- name: >
|
- name: >
|
||||||
Re-check SSH connectivity prior to proceeding with multi-node testing
|
Re-check SSH connectivity prior to proceeding with multi-node testing
|
||||||
wait_for:
|
wait_for:
|
||||||
state: started
|
state: started
|
||||||
port: 22
|
port: 22
|
||||||
host: "{{ ipv4_address }}"
|
host: "{{ ipv4_address }}"
|
||||||
when: ipv4_address is defined and multinode_testing | bool == true
|
when:
|
||||||
|
- ipv4_address is defined
|
||||||
|
- multinode_testing | bool
|
||||||
- name: >
|
- name: >
|
||||||
Additional SSH startup pause when performing multi-node testing
|
Additional SSH startup pause when performing multi-node testing
|
||||||
pause:
|
pause:
|
||||||
seconds: "{{ node_ssh_pause }}"
|
seconds: "{{ node_ssh_pause }}"
|
||||||
when: multinode_testing | bool == true
|
when: multinode_testing | bool
|
||||||
- name: "Add testvm hosts from SSH known_hosts file."
|
- name: "Add testvm hosts from SSH known_hosts file."
|
||||||
shell: ssh-keyscan "{{ ipv4_address }}" >> "{{ ansible_env.HOME }}/.ssh/known_hosts"
|
shell: ssh-keyscan "{{ ipv4_address }}" >> "{{ ansible_env.HOME }}/.ssh/known_hosts"
|
||||||
when: ipv4_address is defined
|
when: ipv4_address is defined
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
owner: root
|
owner: root
|
||||||
group: root
|
group: root
|
||||||
mode: 0644
|
mode: 0644
|
||||||
when: inventory_dhcp | bool == true
|
when: inventory_dhcp | bool
|
||||||
become: yes
|
become: yes
|
||||||
- name: "Setup DNS address for nodes."
|
- name: "Setup DNS address for nodes."
|
||||||
template:
|
template:
|
||||||
@ -35,14 +35,14 @@
|
|||||||
owner: root
|
owner: root
|
||||||
group: root
|
group: root
|
||||||
mode: 0644
|
mode: 0644
|
||||||
when: inventory_dns | bool == true
|
when: inventory_dns | bool
|
||||||
become: yes
|
become: yes
|
||||||
- name: "Sending dnsmasq HUP"
|
- name: "Sending dnsmasq HUP"
|
||||||
# Note(TheJulia): We need to actually to send a hup signal directly as
|
# Note(TheJulia): We need to actually to send a hup signal directly as
|
||||||
# Ansible's reloaded state does not pass through to the init script.
|
# Ansible's reloaded state does not pass through to the init script.
|
||||||
command: killall -HUP dnsmasq
|
command: killall -HUP dnsmasq
|
||||||
become: yes
|
become: yes
|
||||||
when: (inventory_dhcp | bool == true) or (inventory_dns | bool == true)
|
when: inventory_dhcp | bool or inventory_dns | bool
|
||||||
|
|
||||||
- name: "Execute node introspection"
|
- name: "Execute node introspection"
|
||||||
openstack.cloud.baremetal_inspect:
|
openstack.cloud.baremetal_inspect:
|
||||||
|
@ -178,8 +178,8 @@
|
|||||||
become: yes
|
become: yes
|
||||||
gather_facts: yes
|
gather_facts: yes
|
||||||
vars:
|
vars:
|
||||||
inventory_dhcp: "{{ inventory_dhcp | bool == true }}"
|
inventory_dhcp: "{{ inventory_dhcp | bool }}"
|
||||||
inventory_dhcp_static_ip: "{{ inventory_dhcp_static_ip | bool == true }}"
|
inventory_dhcp_static_ip: "{{ inventory_dhcp_static_ip | bool }}"
|
||||||
roles:
|
roles:
|
||||||
- { role: bifrost-test-dhcp, when: inventory_dhcp | bool }
|
- { role: bifrost-test-dhcp, when: inventory_dhcp | bool }
|
||||||
environment:
|
environment:
|
||||||
|
Loading…
Reference in New Issue
Block a user