2021-10-09 23:28:33 +05:30
|
|
|
#!/bin/bash
|
2021-12-01 12:46:28 +05:30
|
|
|
# Copyright 2021 Collate
|
|
|
|
# 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.
|
2021-10-09 23:28:33 +05:30
|
|
|
|
2022-08-31 21:30:24 +02:00
|
|
|
cd "$(dirname "${BASH_SOURCE[0]}")" || exit
|
2022-07-26 17:47:03 +02:00
|
|
|
|
2022-08-31 21:30:24 +02:00
|
|
|
helpFunction()
|
|
|
|
{
|
|
|
|
echo ""
|
|
|
|
echo "Usage: $0 -m mode -d database"
|
2024-01-11 14:23:33 +05:30
|
|
|
echo "\t-m Running mode: [ui, no-ui]. Default [ui]\n"
|
|
|
|
echo "\t-d Database: [mysql, postgresql]. Default [mysql]\n"
|
|
|
|
echo "\t-s Skip maven build: [true, false]. Default [false]\n"
|
|
|
|
echo "\t-x Open JVM debug port on 5005: [true, false]. Default [false]\n"
|
|
|
|
echo "\t-h For usage help\n"
|
|
|
|
echo "\t-r For Cleaning DB Volumes. [true, false]. Default [true]\n"
|
2022-08-31 21:30:24 +02:00
|
|
|
exit 1 # Exit script after printing help
|
|
|
|
}
|
|
|
|
|
2023-06-26 15:44:53 +05:30
|
|
|
while getopts "m:d:s:x:r:h" opt
|
2022-08-31 21:30:24 +02:00
|
|
|
do
|
|
|
|
case "$opt" in
|
|
|
|
m ) mode="$OPTARG" ;;
|
|
|
|
d ) database="$OPTARG" ;;
|
|
|
|
s ) skipMaven="$OPTARG" ;;
|
2022-10-10 22:43:15 -07:00
|
|
|
x ) debugOM="$OPTARG" ;;
|
2022-11-18 18:35:33 +05:30
|
|
|
r ) cleanDbVolumes="$OPTARG" ;;
|
2022-08-31 21:30:24 +02:00
|
|
|
h ) helpFunction ;;
|
|
|
|
? ) helpFunction ;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
mode="${mode:=ui}"
|
|
|
|
database="${database:=mysql}"
|
|
|
|
skipMaven="${skipMaven:=false}"
|
2022-10-10 22:43:15 -07:00
|
|
|
debugOM="${debugOM:=false}"
|
2022-09-23 23:52:28 +05:30
|
|
|
authorizationToken="eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg"
|
2023-06-26 15:44:53 +05:30
|
|
|
cleanDbVolumes="${cleanDbVolumes:=true}"
|
2022-08-31 21:30:24 +02:00
|
|
|
|
2023-06-26 15:44:53 +05:30
|
|
|
echo "Running local docker using mode [$mode] database [$database] and skipping maven build [$skipMaven] with cleanDB as [$cleanDbVolumes]"
|
2022-08-31 21:30:24 +02:00
|
|
|
|
|
|
|
cd ../
|
|
|
|
|
2023-06-12 15:51:05 +05:30
|
|
|
echo "Stopping any previous Local Docker Containers"
|
2024-10-15 16:29:43 +02:00
|
|
|
docker compose -f docker/development/docker-compose-postgres.yml down --remove-orphans
|
|
|
|
docker compose -f docker/development/docker-compose.yml down --remove-orphans
|
2023-06-12 15:51:05 +05:30
|
|
|
|
2022-08-31 21:30:24 +02:00
|
|
|
if [[ $skipMaven == "false" ]]; then
|
|
|
|
if [[ $mode == "no-ui" ]]; then
|
|
|
|
echo "Maven Build - Skipping Tests and UI"
|
2024-09-20 19:30:06 +05:30
|
|
|
mvn -DskipTests -DonlyBackend clean package -pl !openmetadata-ui
|
2022-08-31 21:30:24 +02:00
|
|
|
else
|
|
|
|
echo "Maven Build - Skipping Tests"
|
2024-09-20 19:30:06 +05:30
|
|
|
mvn -DskipTests clean package
|
2022-08-31 21:30:24 +02:00
|
|
|
fi
|
2022-07-26 17:47:03 +02:00
|
|
|
else
|
2022-08-31 21:30:24 +02:00
|
|
|
echo "Skipping Maven Build"
|
2022-07-26 17:47:03 +02:00
|
|
|
fi
|
|
|
|
|
2022-12-23 17:33:30 +01:00
|
|
|
RESULT=$?
|
|
|
|
if [ $RESULT -ne 0 ]; then
|
|
|
|
echo "Failed to run Maven build!"
|
|
|
|
exit 1
|
|
|
|
fi
|
2022-08-31 21:30:24 +02:00
|
|
|
|
2022-10-10 22:43:15 -07:00
|
|
|
if [[ $debugOM == "true" ]]; then
|
|
|
|
export OPENMETADATA_DEBUG=true
|
|
|
|
fi
|
|
|
|
|
2022-11-18 18:35:33 +05:30
|
|
|
if [[ $cleanDbVolumes == "true" ]]
|
|
|
|
then
|
2023-06-26 15:44:53 +05:30
|
|
|
if [[ -d "$PWD/docker/development/docker-volume/" ]]
|
2022-11-18 18:35:33 +05:30
|
|
|
then
|
2023-06-26 15:44:53 +05:30
|
|
|
rm -rf $PWD/docker/development/docker-volume
|
2022-11-18 18:35:33 +05:30
|
|
|
fi
|
|
|
|
fi
|
2022-11-22 11:19:22 +05:30
|
|
|
|
2022-12-23 17:33:30 +01:00
|
|
|
if [[ $VIRTUAL_ENV == "" ]];
|
|
|
|
then
|
|
|
|
echo "Please Use Virtual Environment and make sure to generate Pydantic Models";
|
2022-11-22 11:19:22 +05:30
|
|
|
else
|
2022-12-23 17:33:30 +01:00
|
|
|
echo "Generating Pydantic Models";
|
2022-11-22 11:19:22 +05:30
|
|
|
make install_dev generate
|
|
|
|
fi
|
|
|
|
|
2022-08-31 21:30:24 +02:00
|
|
|
|
2021-11-13 00:00:28 +05:30
|
|
|
echo "Starting Local Docker Containers"
|
2022-08-31 19:01:00 +02:00
|
|
|
echo "Using ingestion dependency: ${INGESTION_DEPENDENCY:-all}"
|
2022-08-31 21:30:24 +02:00
|
|
|
|
|
|
|
if [[ $database == "postgresql" ]]; then
|
2023-03-06 08:58:53 -08:00
|
|
|
docker compose -f docker/development/docker-compose-postgres.yml build --build-arg INGESTION_DEPENDENCY="${INGESTION_DEPENDENCY:-all}" && docker compose -f docker/development/docker-compose-postgres.yml up -d
|
2024-03-12 06:23:05 +01:00
|
|
|
elif [[ $database == "mysql" ]]; then
|
2023-03-06 08:58:53 -08:00
|
|
|
docker compose -f docker/development/docker-compose.yml build --build-arg INGESTION_DEPENDENCY="${INGESTION_DEPENDENCY:-all}" && docker compose -f docker/development/docker-compose.yml up -d
|
2024-03-12 06:23:05 +01:00
|
|
|
else
|
|
|
|
echo "Invalid database type: $database"
|
|
|
|
exit 1
|
2022-08-31 21:30:24 +02:00
|
|
|
fi
|
2022-03-28 11:08:13 +05:30
|
|
|
|
2022-12-23 17:33:30 +01:00
|
|
|
RESULT=$?
|
|
|
|
if [ $RESULT -ne 0 ]; then
|
|
|
|
echo "Failed to start Docker instances!"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2024-08-10 23:56:49 +05:30
|
|
|
until curl -s -f "http://localhost:9200/_cat/indices/openmetadata_team_search_index"; do
|
2024-01-11 14:23:33 +05:30
|
|
|
echo 'Checking if Elastic Search instance is up...\n'
|
2022-03-28 11:08:13 +05:30
|
|
|
sleep 5
|
|
|
|
done
|
2022-12-23 17:33:30 +01:00
|
|
|
|
2022-07-18 14:44:50 +02:00
|
|
|
until curl -s -f --header 'Authorization: Basic YWRtaW46YWRtaW4=' "http://localhost:8080/api/v1/dags/sample_data"; do
|
2024-01-11 14:23:33 +05:30
|
|
|
echo 'Checking if Sample Data DAG is reachable...\n'
|
|
|
|
sleep 5
|
|
|
|
done
|
|
|
|
|
|
|
|
until curl -s -f --header "Authorization: Bearer $authorizationToken" "http://localhost:8585/api/v1/tables"; do
|
|
|
|
echo 'Checking if OM Server is reachable...\n'
|
2022-03-28 11:08:13 +05:30
|
|
|
sleep 5
|
|
|
|
done
|
2022-12-23 17:33:30 +01:00
|
|
|
|
2022-03-28 11:08:13 +05:30
|
|
|
curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_data' \
|
|
|
|
--header 'Authorization: Basic YWRtaW46YWRtaW4=' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--data-raw '{
|
|
|
|
"is_paused": false
|
|
|
|
}'
|
2022-07-18 14:44:50 +02:00
|
|
|
|
2024-01-11 14:23:33 +05:30
|
|
|
curl --location --request PATCH 'localhost:8080/api/v1/dags/extended_sample_data' \
|
|
|
|
--header 'Authorization: Basic YWRtaW46YWRtaW4=' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--data-raw '{
|
|
|
|
"is_paused": false
|
|
|
|
}'
|
|
|
|
|
|
|
|
echo 'Validate sample data DAG...'
|
2022-07-18 14:44:50 +02:00
|
|
|
sleep 5
|
2024-04-11 14:30:40 +02:00
|
|
|
# This validates the sample data DAG flow
|
|
|
|
make install
|
2022-12-23 17:33:30 +01:00
|
|
|
python docker/validate_compose.py
|
2022-07-18 14:44:50 +02:00
|
|
|
|
2022-03-28 11:08:13 +05:30
|
|
|
sleep 5
|
|
|
|
curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_usage' \
|
|
|
|
--header 'Authorization: Basic YWRtaW46YWRtaW4=' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--data-raw '{
|
|
|
|
"is_paused": false
|
|
|
|
}'
|
|
|
|
sleep 5
|
|
|
|
curl --location --request PATCH 'localhost:8080/api/v1/dags/index_metadata' \
|
|
|
|
--header 'Authorization: Basic YWRtaW46YWRtaW4=' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--data-raw '{
|
|
|
|
"is_paused": false
|
|
|
|
}'
|
|
|
|
sleep 2
|
2022-05-25 08:35:16 +02:00
|
|
|
curl --location --request PATCH 'localhost:8080/api/v1/dags/sample_lineage' \
|
|
|
|
--header 'Authorization: Basic YWRtaW46YWRtaW4=' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--data-raw '{
|
|
|
|
"is_paused": false
|
|
|
|
}'
|
2024-01-11 14:23:33 +05:30
|
|
|
|
2023-06-22 16:55:05 +05:30
|
|
|
echo "✔running reindexing"
|
|
|
|
# Trigger ElasticSearch ReIndexing from UI
|
2023-10-10 17:05:07 +05:30
|
|
|
curl --location --request POST 'http://localhost:8585/api/v1/apps/trigger/SearchIndexingApplication' \
|
|
|
|
--header 'Authorization: Bearer eyJraWQiOiJHYjM4OWEtOWY3Ni1nZGpzLWE5MmotMDI0MmJrOTQzNTYiLCJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlzQm90IjpmYWxzZSwiaXNzIjoib3Blbi1tZXRhZGF0YS5vcmciLCJpYXQiOjE2NjM5Mzg0NjIsImVtYWlsIjoiYWRtaW5Ab3Blbm1ldGFkYXRhLm9yZyJ9.tS8um_5DKu7HgzGBzS1VTA5uUjKWOCU0B_j08WXBiEC0mr0zNREkqVfwFDD-d24HlNEbrqioLsBuFRiwIWKc1m_ZlVQbG7P36RUxhuv2vbSp80FKyNM-Tj93FDzq91jsyNmsQhyNv_fNr3TXfzzSPjHt8Go0FMMP66weoKMgW2PbXlhVKwEuXUHyakLLzewm9UMeQaEiRzhiTMU3UkLXcKbYEJJvfNFcLwSl9W8JCO_l0Yj3ud-qt_nQYEZwqW6u5nfdQllN133iikV4fM5QZsMCnm8Rq1mvLR0y9bmJiD7fwM1tmJ791TUWqmKaTnP49U493VanKpUAfzIiOiIbhg'
|
|
|
|
|
2023-06-22 16:55:05 +05:30
|
|
|
sleep 60 # Sleep for 60 seconds to make sure the elasticsearch reindexing from UI finishes
|
2022-03-28 11:08:13 +05:30
|
|
|
tput setaf 2
|
|
|
|
echo "✔ OpenMetadata is up and running"
|
|
|
|
|