Apply reclass patches before salt master init
[fuel.git] / mcp / scripts / lib.sh
1 #
2 # Library of shell functions
3 #
4
5 generate_ssh_key() {
6   [ -f "$SSH_KEY" ] || ssh-keygen -f ${SSH_KEY} -N ''
7   install -o jenkins -m 0600 ${SSH_KEY} /tmp/
8 }
9
10 get_base_image() {
11   local base_image=$1
12
13   mkdir -p images
14   wget -P /tmp -nc $base_image
15 }
16
17 cleanup_vms() {
18   # clean up existing nodes
19   for node in $(virsh list --name | grep -P '\w{3}\d{2}'); do
20     virsh destroy $node
21     virsh undefine $node
22   done
23 }
24
25 prepare_vms() {
26   local -n vnodes=$1
27   local base_image=$2
28
29   cleanup_vms
30   get_base_image $base_image
31   envsubst < user-data.template > user-data.sh
32
33   for node in "${vnodes[@]}"; do
34     # create/prepare images
35     ./create-config-drive.sh -k ${SSH_KEY}.pub -u user-data.sh -h ${node} images/mcp_${node}.iso
36     cp /tmp/${base_image/*\/} images/mcp_${node}.qcow2
37     qemu-img resize images/mcp_${node}.qcow2 100G
38   done
39 }
40
41 create_networks() {
42   # create required networks
43   for net in pxe mgmt internal public; do
44     if virsh net-info $net >/dev/null 2>&1; then
45       virsh net-destroy ${net}
46       virsh net-undefine ${net}
47     fi
48     virsh net-define net_${net}.xml
49     virsh net-autostart ${net}
50     virsh net-start ${net}
51   done
52 }
53
54 create_vms() {
55   local -n vnodes=$1
56   local -n vnodes_ram=$2
57
58   # create vms with specified options
59   for node in "${vnodes[@]}"; do
60     virt-install --name ${node} --ram ${vnodes_ram[$node]} --vcpus=2 --cpu host --accelerate \
61     --network network:pxe,model=virtio \
62     --network network:mgmt,model=virtio \
63     --network network:internal,model=virtio \
64     --network network:public,model=virtio \
65     --disk path=$(pwd)/images/mcp_${node}.qcow2,format=qcow2,bus=virtio,cache=none,io=native \
66     --os-type linux --os-variant none \
67     --boot hd --vnc --console pty --autostart --noreboot \
68     --disk path=$(pwd)/images/mcp_${node}.iso,device=cdrom
69   done
70 }
71
72 update_pxe_network() {
73   # set static ip address for salt master node
74   virsh net-update pxe add ip-dhcp-host \
75   "<host mac='$(virsh domiflist cfg01 | awk '/pxe/ {print $5}')' name='cfg01' ip='$SALT_MASTER'/>" --live
76 }
77
78 start_vms() {
79   local -n vnodes=$1
80
81   # start vms
82   for node in "${vnodes[@]}"; do
83     virsh start ${node}
84     sleep $[RANDOM%5+1]
85   done
86 }
87
88 check_connection() {
89   local total_attempts=60
90   local sleep_time=5
91   local attempt=1
92
93   set +e
94   echo '[INFO] Attempting to get into Salt master ...'
95
96   # wait until ssh on Salt master is available
97   while (($attempt <= $total_attempts)); do
98     ssh ${SSH_OPTS} ubuntu@${SALT_MASTER} uptime
99     case $? in
100       0) echo "${attempt}> Success"; break ;;
101       *) echo "${attempt}/${total_attempts}> ssh server ain't ready yet, waiting for ${sleep_time} seconds ..." ;;
102     esac
103     sleep $sleep_time
104     ((attempt+=1))
105   done
106   set -e
107 }
108
109 parse_yaml() {
110   local prefix=$2
111   local s
112   local w
113   local fs
114   s='[[:space:]]*'
115   w='[a-zA-Z0-9_]*'
116   fs="$(echo @|tr @ '\034')"
117   sed -ne "s|^\($s\)\($w\)$s:$s\"\(.*\)\"$s\$|\1$fs\2$fs\3|p" \
118       -e "s|^\($s\)\($w\)$s[:-]$s\(.*\)$s\$|\1$fs\2$fs\3|p" "$1" |
119   awk -F"$fs" '{
120   indent = length($1)/2;
121   vname[indent] = $2;
122   for (i in vname) {if (i > indent) {delete vname[i]}}
123       if (length($3) > 0) {
124           vn=""; for (i=0; i<indent; i++) {vn=(vn)(vname[i])("_")}
125           printf("%s%s%s=(\"%s\")\n", "'"$prefix"'",vn, $2, $3);
126       }
127   }' | sed 's/_=/+=/g'
128 }