--- - hosts: all tasks: - name: 'disable tempfs on Fedora' become: yes command: systemctl mask tmp.mount # noqa 303 when: ansible_distribution == 'Fedora' ignore_errors: yes - name: Register as user '{{ rh_username }}' and auto-subscribe to available content become: yes redhat_subscription: state: present username: '{{ rh_username }}' password: '{{ rh_password }}' auto_attach: yes when: - rh_username is defined - (rh_username | length) > 0 - hosts: primary tasks: - name: "copy /etc/resolv.conf" become: yes copy: src: /etc/resolv.conf dest: /etc/resolv.conf owner: root group: root mode: '0644' - name: "make /etc/hosts" become: yes template: src: 'hosts.j2' dest: '/etc/hosts' owner: root mode: '0644' - name: "make ~/.ssh/config file with all Vagrant nodes" template: src: 'ssh_config.j2' dest: '/home/vagrant/.ssh/config' owner: vagrant mode: '0600' - name: "generate local SSH key '{{ ssh_key_file }}'" openssh_keypair: path: '{{ ssh_key_file }}' type: rsa size: 4096 state: present force: no delegate_to: localhost - name: "copy '{{ ssh_key_file }}' file to host" copy: src: '{{ ssh_key_file }}{{ item }}' dest: '/home/vagrant/.ssh/id_rsa{{ item }}' owner: vagrant group: vagrant mode: '0600' loop: - '' - '.pub' - hosts: all tasks: - name: "update APT database" apt: update_cache: yes cache_valid_time: 3600 become: yes when: - ansible_os_family == 'Debian' - name: "set authorized SSH key taken from '{{ ssh_key_file }}'" authorized_key: user: vagrant state: present key: "{{ lookup('file', ssh_key_file + '.pub') }}" - name: "ensure deploy tools are installed" become: true package: name='{{ item }}' loop: - git - rsync - hosts: primary tasks: - name: "check ICMP connectivity" shell: | set -xe ping -c 1 '{{ item.1.ip }}' ping -c 1 '{{ item.1.hostname }}' changed_when: false register: check_icmp_connectivity loop: '{{ vagrant_nodes | dictsort }}' - name: "check SSH connectivity via hostname" shell: | set -xe ssh '{{ item.1.ip }}' hostname ssh '{{ item.1.hostname }}' hostname ssh '{{ item.0 }}' hostname changed_when: false register: check_ssh_connectivity loop: '{{ vagrant_nodes | dictsort }}' - name: "set test_inventory_hostvars_yaml fact" set_fact: test_inventory_hostvars_yaml: | --- {% for name, node in (vagrant_nodes | dictsort) %} {{ name }}: ansible_host: {{ node.hostname }} {% endfor %} - name: "set test_inventory_hostvars fact" set_fact: test_inventory_hostvars: '{{ test_inventory_hostvars_yaml | from_yaml }}' - debug: var=test_inventory_hostvars - hosts: primary roles: - role: tobiko-inventory tasks: - name: "copy '{{ tobiko_src_dir }}' to '{{ tobiko_dir }}'" synchronize: src: "{{ tobiko_src_dir | realpath }}/." dest: "{{ tobiko_dir | realpath }}" use_ssh_args: yes recursive: yes rsync_opts: - '--exclude-from={{ tobiko_src_dir | realpath }}/.gitignore'