| 1 | --- |
| 2 | - hosts: lxd_cluster_ci:localhost |
| 3 | vars_files: |
| 4 | - ../vars/ci-instances.yml |
| 5 | - ../roles/lxd/defaults/main.yml |
| 6 | - ../roles/libvirt/vars/main.yml |
| 7 | vars: |
| 8 | skip_libvirt: false |
| 9 | skip_lxd: false |
| 10 | skip_dns: false |
| 11 | skip_jenkins: false |
| 12 | jenkins_config: "~/.config/jenkins_jobs/jenkins_jobs.ini" |
| 13 | jenkins_default_credentials: "c3e4f9f2-3e89-474d-bc75-6251a13e1053" |
| 14 | tasks: |
| 15 | - name: Manage instances |
| 16 | when: item.lxd|default(false) and not skip_lxd and inventory_hostname == lxd_host |
| 17 | include_tasks: |
| 18 | file: '../roles/lxd/tasks/container.yml' |
| 19 | vars: |
| 20 | object: >- |
| 21 | {{item.lxd| |
| 22 | combine({'config':{'user.network-config': lookup('ansible.builtin.template', |
| 23 | '../templates/cloud_init_netconf.j2', |
| 24 | template_vars=item.meta |
| 25 | ) |
| 26 | } |
| 27 | }, |
| 28 | recursive=true |
| 29 | )}} |
| 30 | with_items: "{{containers}}" |
| 31 | - name: Manage Libvirt VMs |
| 32 | when: item.vm|default(false) and not skip_libvirt and inventory_hostname == item.vm.host|default(libvirt_host) |
| 33 | include_tasks: |
| 34 | file: '../roles/libvirt/tasks/vm.yml' |
| 35 | vars: |
| 36 | object: "{{item.vm}}" |
| 37 | with_items: "{{containers}}" |
| 38 | - name: Update DNS entries |
| 39 | when: not skip_dns and inventory_hostname == 'localhost' |
| 40 | with_items: "{{containers}}" |
| 41 | ansible.builtin.command: |
| 42 | argv: [ |
| 43 | '../scripts/update_dns_entry.py', '-n', "{{item.lxd.name|default(item.vm.name)}}", |
| 44 | '-z', "{{search_domain}}", |
| 45 | '-v', "{{item.meta.address}}", |
| 46 | '-s', "{{name_server}}", |
| 47 | ] |
| 48 | - name: Update Jenkins nodes |
| 49 | when: item.jenkins|default(false) and not skip_jenkins and inventory_hostname == 'localhost' |
| 50 | with_items: "{{containers}}" |
| 51 | vars: |
| 52 | node_name: "{{item.jenkins.node_name|default(item.lxd.name|default(item.vm.name))}}" |
| 53 | node_ip: "{{item.meta.address|default(None)}}" |
| 54 | node_host: "{{item.meta.jenkins.node_host|default(item.lxd.name|default(item.vm.name) + '.' + search_domain)}}" |
| 55 | node_label: "{{item.jenkins.label|default('')}}" |
| 56 | node_state: "{{item.jenkins.state|default('online')}}" |
| 57 | node_credentials: "{{item.jenkins.credentials|default(jenkins_default_credentials)}}" |
| 58 | node_message: "{{item.jenkins.message|default('Set offline by ansible')}}" |
| 59 | node_mode: "{{item.jenkins.mode|default('NORMAL')}}" |
| 60 | node_json: "{{item.jenkins.config|default({})|to_json}}" |
| 61 | ansible.builtin.command: |
| 62 | argv: [ |
| 63 | '../scripts/update_jenkins_node.py', '-n', "{{node_name}}", |
| 64 | '-c', "launcher/host={{node_ip|default(node_host)}}", |
| 65 | '-c', "label={{node_label}}", |
| 66 | '-c', "launcher/credentialsId={{node_credentials}}", |
| 67 | '-c', "launcher/sshHostKeyVerificationStrategy=hudson.plugins.sshslaves.verifiers.ManuallyTrustedKeyVerificationStrategy=class", |
| 68 | '-c', "mode={{node_mode}}", |
| 69 | '-s', "{{node_state}}", '-m', "{{node_message}}", |
| 70 | '-f', "{{jenkins_config|expanduser}}", |
| 71 | '-j', "{{node_json}}", |
| 72 | ] |