db79e79788
The current copyright refers to a non-existent group "openstack helm authors" with often out-of-date references that are confusing when adding a new file to the repo. This change removes all references to this copyright by the non-existent group and any blank lines underneath. Change-Id: Ia035037e000f1bf95202fc07b8cd1ad0fc019094
181 lines
5.1 KiB
Bash
Executable File
181 lines
5.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# 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.
|
|
set -xe
|
|
|
|
#NOTE: Deploy nova
|
|
tee /tmp/nova.yaml << EOF
|
|
labels:
|
|
api_metadata:
|
|
node_selector_key: openstack-helm-node-class
|
|
node_selector_value: primary
|
|
pod:
|
|
replicas:
|
|
api_metadata: 1
|
|
placement: 2
|
|
osapi: 2
|
|
conductor: 2
|
|
consoleauth: 2
|
|
scheduler: 1
|
|
novncproxy: 1
|
|
EOF
|
|
|
|
function kvm_check () {
|
|
POD_NAME="tmp-$(cat /dev/urandom | env LC_CTYPE=C tr -dc a-z | head -c 5; echo)"
|
|
cat <<EOF | kubectl apply -f - 1>&2;
|
|
apiVersion: v1
|
|
kind: Pod
|
|
metadata:
|
|
name: ${POD_NAME}
|
|
spec:
|
|
hostPID: true
|
|
restartPolicy: Never
|
|
containers:
|
|
- name: util
|
|
securityContext:
|
|
privileged: true
|
|
image: docker.io/busybox:latest
|
|
command:
|
|
- sh
|
|
- -c
|
|
- |
|
|
nsenter -t1 -m -u -n -i -- sh -c "kvm-ok >/dev/null && echo yes || echo no"
|
|
EOF
|
|
end=$(($(date +%s) + 900))
|
|
until kubectl get pod/${POD_NAME} -o go-template='{{.status.phase}}' | grep -q Succeeded; do
|
|
now=$(date +%s)
|
|
[ $now -gt $end ] && echo containers failed to start. && \
|
|
kubectl get pod/${POD_NAME} -o wide && exit 1
|
|
done
|
|
kubectl logs pod/${POD_NAME}
|
|
kubectl delete pod/${POD_NAME} 1>&2;
|
|
}
|
|
|
|
if [ "x$(kvm_check)" == "xyes" ]; then
|
|
echo 'OSH is not being deployed in virtualized environment'
|
|
helm upgrade --install nova ./nova \
|
|
--namespace=openstack \
|
|
--values=/tmp/nova.yaml \
|
|
${OSH_EXTRA_HELM_ARGS} \
|
|
${OSH_EXTRA_HELM_ARGS_NOVA}
|
|
else
|
|
echo 'OSH is being deployed in virtualized environment, using qemu for nova'
|
|
helm upgrade --install nova ./nova \
|
|
--namespace=openstack \
|
|
--values=/tmp/nova.yaml \
|
|
--set conf.nova.libvirt.virt_type=qemu \
|
|
--set conf.nova.libvirt.cpu_mode=none \
|
|
${OSH_EXTRA_HELM_ARGS} \
|
|
${OSH_EXTRA_HELM_ARGS_NOVA}
|
|
fi
|
|
|
|
#NOTE: Deploy neutron, for simplicity we will assume the default route device
|
|
# should be used for tunnels
|
|
function network_tunnel_dev () {
|
|
POD_NAME="tmp-$(cat /dev/urandom | env LC_CTYPE=C tr -dc a-z | head -c 5; echo)"
|
|
cat <<EOF | kubectl apply -f - 1>&2;
|
|
apiVersion: v1
|
|
kind: Pod
|
|
metadata:
|
|
name: ${POD_NAME}
|
|
spec:
|
|
hostNetwork: true
|
|
restartPolicy: Never
|
|
containers:
|
|
- name: util
|
|
image: docker.io/busybox:latest
|
|
command:
|
|
- 'ip'
|
|
- '-4'
|
|
- 'route'
|
|
- 'list'
|
|
- '0/0'
|
|
EOF
|
|
end=$(($(date +%s) + 900))
|
|
until kubectl get pod/${POD_NAME} -o go-template='{{.status.phase}}' | grep -q Succeeded; do
|
|
now=$(date +%s)
|
|
[ $now -gt $end ] && echo containers failed to start. && \
|
|
kubectl get pod/${POD_NAME} -o wide && exit 1
|
|
done
|
|
kubectl logs pod/${POD_NAME} | awk '{ print $5; exit }'
|
|
kubectl delete pod/${POD_NAME} 1>&2;
|
|
}
|
|
|
|
NETWORK_TUNNEL_DEV="$(network_tunnel_dev)"
|
|
tee /tmp/neutron.yaml << EOF
|
|
network:
|
|
interface:
|
|
tunnel: "${NETWORK_TUNNEL_DEV}"
|
|
labels:
|
|
agent:
|
|
dhcp:
|
|
node_selector_key: openstack-helm-node-class
|
|
node_selector_value: primary
|
|
l3:
|
|
node_selector_key: openstack-helm-node-class
|
|
node_selector_value: primary
|
|
metadata:
|
|
node_selector_key: openstack-helm-node-class
|
|
node_selector_value: primary
|
|
pod:
|
|
replicas:
|
|
server: 2
|
|
conf:
|
|
neutron:
|
|
DEFAULT:
|
|
l3_ha: False
|
|
max_l3_agents_per_router: 1
|
|
l3_ha_network_type: vxlan
|
|
dhcp_agents_per_network: 1
|
|
plugins:
|
|
ml2_conf:
|
|
ml2_type_flat:
|
|
flat_networks: public
|
|
openvswitch_agent:
|
|
agent:
|
|
tunnel_types: vxlan
|
|
ovs:
|
|
bridge_mappings: public:br-ex
|
|
EOF
|
|
|
|
if [ -n "$OSH_OPENSTACK_RELEASE" ]; then
|
|
if [ -e "./neutron/values_overrides/${OSH_OPENSTACK_RELEASE}.yaml" ] ; then
|
|
echo "Adding release overrides for ${OSH_OPENSTACK_RELEASE}"
|
|
OSH_RELEASE_OVERRIDES_NEUTRON="--values=./neutron/values_overrides/${OSH_OPENSTACK_RELEASE}.yaml"
|
|
fi
|
|
fi
|
|
|
|
helm upgrade --install neutron ./neutron \
|
|
--namespace=openstack \
|
|
--values=/tmp/neutron.yaml \
|
|
${OSH_RELEASE_OVERRIDES_NEUTRON} \
|
|
${OSH_EXTRA_HELM_ARGS} \
|
|
${OSH_EXTRA_HELM_ARGS_NEUTRON}
|
|
|
|
#NOTE: Wait for deploy
|
|
./tools/deployment/common/wait-for-pods.sh openstack
|
|
|
|
#NOTE: Validate Deployment info
|
|
export OS_CLOUD=openstack_helm
|
|
openstack service list
|
|
sleep 30 #NOTE(portdirect): Wait for ingress controller to update rules and restart Nginx
|
|
openstack compute service list
|
|
openstack network agent list
|
|
# Delete the test pods if they still exist
|
|
kubectl delete pods -l application=nova,release_group=nova,component=test --namespace=openstack --ignore-not-found
|
|
kubectl delete pods -l application=neutron,release_group=neutron,component=test --namespace=openstack --ignore-not-found
|
|
|
|
timeout=${OSH_TEST_TIMEOUT:-900}
|
|
helm test nova --timeout $timeout
|
|
helm test neutron --timeout $timeout
|