1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
|
#!/bin/bash
# Copyright 2016 AT&T Intellectual Property, Inc
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# What this is: Deployment test for the Tacker Hello World blueprint.
#
# Status: this is a work in progress, under test.
#
# How to use:
# $ git clone https://gerrit.opnfv.org/gerrit/models
# $ cd models/tests
# $ bash vLamp_Ansible.sh [setup|start|run|stop|clean]
# setup: setup test environment
# start: install blueprint and run test
# run: setup test environment and run test
# stop: stop test and uninstall blueprint
# clean: cleanup after test
trap 'fail' ERR
pass() {
echo "$0: Hooray!"
set +x #echo off
exit 0
}
fail() {
echo "$0: Test Failed!"
set +x
exit 1
}
get_floating_net () {
network_ids=($(neutron net-list|grep -v "+"|grep -v name|awk '{print $2}'))
for id in ${network_ids[@]}; do
[[ $(neutron net-show ${id}|grep 'router:external'|grep -i "true") != "" ]] && FLOATING_NETWORK_ID=${id}
done
if [[ $FLOATING_NETWORK_ID ]]; then
FLOATING_NETWORK_NAME=$(openstack network show $FLOATING_NETWORK_ID | awk "/ name / { print \$4 }")
else
echo "$0: Floating network not found"
exit 1
fi
}
try () {
count=$1
$3
while [[ $? -eq 1 && $count -gt 0 ]]
do
sleep $2
let count=$count-1
$3
done
if [[ $count -eq 0 ]]; then echo "$0: Command \"$3\" was not successful after $1 tries"; fi
}
setup () {
echo "$0: Setup temp test folder /tmp/ansible and copy this script there"
if [ -d /tmp/ansible ]; then sudo rm -rf /tmp/ansible; fi
mkdir -p /tmp/ansible
chmod 777 /tmp/ansible/
cp $0 /tmp/ansible/.
chmod 755 /tmp/ansible/*.sh
echo "$0: ansible-setup part 1"
bash utils/ansible-setup.sh init
echo "$0: ansible-setup part 2"
CONTAINER=$(sudo docker ps -l | awk "/ansible/ { print \$1 }")
dist=`grep DISTRIB_ID /etc/*-release | awk -F '=' '{print $2}'`
if [ "$dist" == "Ubuntu" ]; then
echo "$0: Execute ansible-setup.sh in the container"
sudo docker exec -it $CONTAINER /bin/bash /tmp/ansible/ansible-setup.sh setup
else
echo "$0: Execute ansible-setup.sh in the container"
sudo docker exec -i -t $CONTAINER /bin/bash /tmp/ansible/ansible-setup.sh setup
fi
echo "$0: reset blueprints folder"
if [[ -d /tmp/ansible/blueprints/lampstack ]]; then rm -rf /tmp/ansible/blueprints/lampstack; fi
mkdir -p /tmp/ansible/blueprints/
echo "$0: copy lampstack to blueprints folder"
cd /tmp/
git clone https://github.com/openstack/osops-tools-contrib.git
cp -r osops-tools-contrib/ansible/lampstack /tmp/ansible/blueprints
echo "$0: setup OpenStack environment"
source /tmp/ansible/admin-openrc.sh
echo "$0: determine external (public) network as the floating ip network"
get_floating_net
echo "$0: create lampstack vars file for OPNFV"
# trusty-server is needed since xenial does not come with python pre-installed
# TODO: find some way to get ansible to install dependencies!
cat >/tmp/ansible/blueprints/lampstack/vars/opnfv.yml <<EOF
---
horizon_url: "http://$HORIZON_HOST"
auth: {
auth_url: "$OS_AUTH_URL",
username: "admin",
password: "{{ password }}",
project_name: "admin"
}
app_env: {
image_name: "trusty-server",
region_name: "$OS_REGION_NAME",
availability_zone: "nova",
validate_certs: True,
private_net_name: "internal",
public_net_name: "$FLOATING_NETWORK_NAME",
flavor_name: "m1.small",
public_key_file: "/tmp/ansible/ansible.pub",
stack_size: 4,
volume_size: 2,
block_device_name: "/dev/vdb",
wp_theme: "https://downloads.wordpress.org/theme/iribbon.2.0.65.zip",
wp_posts: "http://wpcandy.s3.amazonaws.com/resources/postsxml.zip"
}
EOF
echo "$0: Disable host key checking (fix for SSH connection issues?)"
echo "host_key_checking = False" >>/tmp/ansible/blueprints/lampstack/ansible.cfg
echo "$0: Setup trusty-server glance image if needed"
if [[ -z $(openstack image list | awk "/ trusty-server / { print \$2 }") ]]; then glance --os-image-api-version 1 image-create --name trusty-server --disk-format qcow2 --location https://cloud-images.ubuntu.com/trusty/current/trusty-server-cloudimg-amd64-disk1.img --container-format bare; fi
if [[ -z $(neutron net-list | awk "/ internal / { print \$2 }") ]]; then
echo "$0: Create internal network"
neutron net-create internal
echo "$0: Create internal subnet"
neutron subnet-create internal 10.0.0.0/24 --name internal --gateway 10.0.0.1 --enable-dhcp --allocation-pool start=10.0.0.2,end=10.0.0.254 --dns-nameserver 8.8.8.8
fi
if [[ -z $(neutron router-list | awk "/ public_router / { print \$2 }") ]]; then
echo "$0: Create router"
neutron router-create public_router
echo "$0: Create router gateway"
neutron router-gateway-set public_router $FLOATING_NETWORK_NAME
echo "$0: Add router interface for internal network"
neutron router-interface-add public_router subnet=internal
fi
}
start() {
echo "$0: Add ssh key"
chown root /tmp/ansible/ansible
eval $(ssh-agent -s)
ssh-add /tmp/ansible/ansible
echo "$0: setup OpenStack environment"
source /tmp/ansible/admin-openrc.sh
echo "$0: Clear known hosts (workaround for ssh connection issues)"
rm ~/.ssh/known_hosts
echo "$0: invoke blueprint install via Ansible"
cd /tmp/ansible/blueprints/lampstack
ansible-playbook -vvv -e "action=apply env=opnfv password=$OS_PASSWORD" site.yml
pass
}
stop() {
echo "$0: Add ssh key"
eval $(ssh-agent -s)
ssh-add /tmp/ansible/ansible
echo "$0: setup OpenStack environment"
source /tmp/ansible/admin-openrc.sh
echo "$0: invoke blueprint destroy via Ansible"
cd /tmp/ansible/blueprints/lampstack
ansible-playbook -vvv -e "action=destroy env=opnfv password=$OS_PASSWORD" site.yml
pass
}
forward_to_container () {
echo "$0: pass $1 command to vLamp_Ansible.sh in tacker container"
CONTAINER=$(sudo docker ps -a | awk "/ansible/ { print \$1 }")
sudo docker exec $CONTAINER /bin/bash /tmp/ansible/vLamp_Ansible.sh $1 $1
if [ $? -eq 1 ]; then fail; fi
}
dist=`grep DISTRIB_ID /etc/*-release | awk -F '=' '{print $2}'`
case "$1" in
setup)
setup
pass
;;
run)
setup
forward_to_container start
pass
;;
start|stop)
if [[ $# -eq 1 ]]; then forward_to_container $1
else
# running inside the tacker container, ready to go
$1
fi
pass
;;
clean)
echo "$0: Uninstall Ansible and test environment"
bash utils/ansible-setup.sh clean
pass
;;
*)
echo "usage: bash vLamp_Ansible.sh [setup|start|run|clean]"
echo "setup: setup test environment"
echo "start: install blueprint and run test"
echo "run: setup test environment and run test"
echo "stop: stop test and uninstall blueprint"
echo "clean: cleanup after test"
fail
esac
|