From 8a378cf4cadee71cffa483cf90514dbd1ba872a9 Mon Sep 17 00:00:00 2001 From: nathanmartinszup <63246935+nathanmartinszup@users.noreply.github.com> Date: Fri, 11 Mar 2022 14:50:48 -0300 Subject: [PATCH] install.sh/bugfix - fixing error in intall script (#164) Previously the analytics database is not being created, as the postgresql-client was not waiting for the database pod to be ready. This pull request adds a sleep to avoid this issue. Signed-off-by: Nathan Martins --- config/samples/sample_install_dependencies.sh | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/config/samples/sample_install_dependencies.sh b/config/samples/sample_install_dependencies.sh index df0cd08..976d4b0 100755 --- a/config/samples/sample_install_dependencies.sh +++ b/config/samples/sample_install_dependencies.sh @@ -28,6 +28,10 @@ echo "Adding installing dependencies..." helm install rabbitmq bitnami/rabbitmq helm install postgresql --set auth.database=horusec_db bitnami/postgresql +# necessary to avoid the command 'kubectl wait --for=condition=ready pod postgresql-0 --timeout 300s' run before the +# pod even exits. +sleep 5 + echo "Getting user and pwd of dependencies..." export POSTGRES_USERNAME="postgres" export POSTGRES_PASSWORD=$(kubectl get secret postgresql -o jsonpath="{.data.postgres-password}" | base64 --decode) @@ -35,11 +39,6 @@ export RABBITMQ_USERNAME="user" export RABBITMQ_PASSWORD=$(kubectl get secret rabbitmq -o jsonpath="{.data.rabbitmq-password}" | base64 --decode) export JWT_SECRET="4ff42f67-5929-fc52-65f1-3afc77ad86d5" -# waits for postgres to be ready -kubectl wait --for=condition=ready pod postgresql-0 --timeout 300s - -kubectl run postgresql-client --rm -it --restart='Never' --image docker.io/bitnami/postgresql --env="PGPASSWORD=$POSTGRES_PASSWORD" --command -- psql --host postgresql -U $POSTGRES_USERNAME -d horusec_db -p 5432 --no-password -c "create database horusec_analytic_db;" - echo "Creating secrets of dependencies..." kubectl create secret generic horusec-platform-database --from-literal="username=$POSTGRES_USERNAME" --from-literal="password=$POSTGRES_PASSWORD" kubectl create secret generic horusec-analytic-database --from-literal="username=$POSTGRES_USERNAME" --from-literal="password=$POSTGRES_PASSWORD" @@ -47,3 +46,9 @@ kubectl create secret generic horusec-analytic-database --from-literal="username kubectl create secret generic horusec-broker --from-literal="username=$RABBITMQ_USERNAME" --from-literal="password=$RABBITMQ_PASSWORD" kubectl create secret generic horusec-jwt --from-literal=jwt-token=$JWT_SECRET + +# waits for postgres to be ready +kubectl wait --for=condition=ready pod postgresql-0 --timeout 300s + +# creates horusec_analytic_db +kubectl run postgresql-client --rm -it --restart='Never' --image docker.io/bitnami/postgresql --env="PGPASSWORD=$POSTGRES_PASSWORD" --command -- psql --host postgresql -U $POSTGRES_USERNAME -d horusec_db -p 5432 --no-password -c "create database horusec_analytic_db;"