|  | {% from 'cookied-bm-mcp-ocata-contrail-nfv/underlay.yaml' import HOSTNAME_CFG01 with context %} | 
|  | {% from 'cookied-bm-mcp-ocata-contrail-nfv/underlay.yaml' import HOSTNAME_GTW01 with context %} | 
|  | {% from 'shared-salt.yaml' import IPV4_NET_EXTERNAL_PREFIX with context %} | 
|  | {% from 'shared-salt.yaml' import IPV4_NET_TENANT_PREFIX with context %} | 
|  | {% set PATTERN = os_env('PATTERN', 'false') %} | 
|  | {% set RUN_TEMPEST = os_env('RUN_TEMPEST', 'false') %} | 
|  |  | 
|  | {% import 'shared-openstack.yaml' as SHARED_OPENSTACK with context %} | 
|  |  | 
|  | # Install OpenStack control services | 
|  |  | 
|  | {{ SHARED_OPENSTACK.MACRO_INSTALL_KEYSTONE() }} | 
|  |  | 
|  | {{ SHARED_OPENSTACK.MACRO_INSTALL_GLANCE() }} | 
|  |  | 
|  | {{ SHARED_OPENSTACK.MACRO_INSTALL_NOVA() }} | 
|  |  | 
|  | {{ SHARED_OPENSTACK.MACRO_INSTALL_CINDER(INSTALL_VOLUME=false) }} | 
|  |  | 
|  | - description: WR Install cinder volume | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@cinder:volume' state.sls cinder | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | {{ SHARED_OPENSTACK.MACRO_INSTALL_NEUTRON(INSTALL_GATEWAY=false) }} | 
|  |  | 
|  | # install contrail | 
|  | - description: Install Opencontrail db on ctl01 | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:database and *01*' state.sls opencontrail.database | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 20} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Opencontrail db on all nodes | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:database' state.sls opencontrail.database | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 20} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Opencontrail control on ctl01 | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:control and *01*' state.sls opencontrail exclude=opencontrail.client | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Opencontrail control on all nodes | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:control' state.sls opencontrail exclude=opencontrail.client | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Opencontrail on collector | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:collector' state.sls opencontrail exclude=opencontrail.client | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Workaround for https://mirantis.jira.com/browse/PROD-12798 | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:control' service.restart 'keepalived' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | # OpenContrail vrouters | 
|  | - description: Install Opencontrail client | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:database:id:1' state.sls 'opencontrail.client' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Opencontrail client on computes | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:compute' state.sls 'opencontrail.client' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | # The next four steps should be converted to one (state.sls opencontrail)  with skip_fail: false | 
|  | # It is related to bug with hugepages. So we need to add WR, then reboot | 
|  | # for only 1G hugepages were mounted. Then re-apply state | 
|  | - description: Install Opencontrail on computes | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:compute' state.sls 'opencontrail' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Hack vrouter (Delete default moun point) | 
|  | cmd: salt "cmp*" cmd.run "sed -i 's/exit 0//g' /etc/rc.local; echo 'umount /dev/hugepages; service supervisor-vrouter restart' >> /etc/rc.local; echo 'exit 0' >> /etc/rc.local" | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Reboot computes | 
|  | cmd: salt --timeout=600  "cmp*" system.reboot | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Install Opencontrail on computes | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:compute' state.sls 'opencontrail' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Remove crashes files from /var/crashes/ while vrouter was crashed | 
|  | cmd: salt  "cmp*" cmd.run "rm -rf /var/crashes/*" | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Test Opencontrail | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@opencontrail:control' cmd.run 'contrail-status' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | {{ SHARED_OPENSTACK.MACRO_INSTALL_HEAT() }} | 
|  |  | 
|  | - description: Deploy horizon dashboard | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@horizon:server' state.sls horizon | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Deploy nginx proxy | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@nginx:server' state.sls nginx | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: true | 
|  |  | 
|  | # Install compute node | 
|  | - description: Apply formulas for compute node | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'cmp*' state.apply | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Re-apply(as in doc) formulas for compute node | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'cmp*' state.apply | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Check IP on computes | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'cmp*' cmd.run | 
|  | 'ip a' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 10, delay: 30} | 
|  | skip_fail: false | 
|  |  | 
|  | # Upload cirros image | 
|  | - description: Upload cirros image on ctl01 | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run | 
|  | 'wget http://download.cirros-cloud.net/0.3.4/cirros-0.3.4-i386-disk.img' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 30} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Register image in glance | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run | 
|  | '. /root/keystonercv3; glance --timeout 120 image-create --name cirros --visibility public --disk-format qcow2 --container-format bare --progress < /root/cirros-0.3.4-i386-disk.img' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: sync time | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False '*' cmd.run | 
|  | 'service ntp stop; ntpd -gq;  service ntp start' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install docker.io on ctl | 
|  | cmd: salt "ctl01*" cmd.run 'apt-get install docker.io -y' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Enable forward policy | 
|  | cmd: salt "ctl01*" cmd.run 'iptables --policy FORWARD ACCEPT' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Hack resolv.conf on VCP nodes for internal services access | 
|  | cmd: | | 
|  | salt --hard-crash --state-output=mixed --state-verbose=False -C '* and not kvm* and not cmp* and not gtw* and not cfg*' cmd.run "echo 'nameserver 172.18.208.44' > /etc/resolv.conf;" | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Reboot computes | 
|  | cmd: | | 
|  | salt "cmp*" system.reboot; | 
|  | sleep 600; | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 30} | 
|  | skip_fail: true |