The `./btrix` development helper shouldn't be used for anything other than local dev, which this commit helps to enforce. When running any command, if the k8s context is anything other than `docker-desktop` the script will now shut down immediately without doing anything and print the message: "Attempting to modify context other than docker-desktop not supported. Quitting."
214 lines
5.1 KiB
Bash
Executable File
214 lines
5.1 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# ./btrix: Browsertrix dev environment utility
|
|
#
|
|
# Test commands require installing pytest first, e.g.:
|
|
# python3 -m pip install pytest
|
|
#
|
|
# Usage:
|
|
#
|
|
# $ ./btrix setup
|
|
# Copy local config to expected location
|
|
# Local config must exist for other commands to work
|
|
#
|
|
# $ ./btrix bootstrap
|
|
# Build frontend and backend and upgrade
|
|
# Optional args:
|
|
# -microk8s: Preface kubectl/helm commands with microk8s
|
|
# -wait: Wait until pods are ready
|
|
#
|
|
# $ ./btrix reset
|
|
# Uninstall, delete data, then bootstrap
|
|
# Optional args:
|
|
# -microk8s: Preface kubectl/helm commands with microk8s
|
|
# -wait: Wait until pods are ready
|
|
#
|
|
# $ ./btrix down
|
|
# Uninstall and delete data
|
|
# Optional args:
|
|
# -microk8s: Preface kubectl/helm commands with microk8s
|
|
#
|
|
# $ ./btrix test
|
|
# Run backend tests
|
|
#
|
|
# $ ./btrix nightly
|
|
# Run nightly backend tests
|
|
|
|
|
|
bootstrap(){
|
|
echo "Building backend..."
|
|
./scripts/build-backend.sh
|
|
|
|
echo "Building frontend..."
|
|
./scripts/build-frontend.sh
|
|
|
|
echo "Installing..."
|
|
helm upgrade --install -f ./chart/values.yaml -f ./chart/local.yaml btrix ./chart
|
|
}
|
|
|
|
bootstrapMicrok8s(){
|
|
echo "Building backend..."
|
|
./scripts/build-backend.sh
|
|
|
|
echo "Building frontend..."
|
|
./scripts/build-frontend.sh
|
|
|
|
echo "Installing..."
|
|
microk8s helm3 upgrade --install -f ./chart/values.yaml -f ./chart/local.yaml btrix ./chart
|
|
}
|
|
|
|
waitUntilReady(){
|
|
echo "Waiting until ready..."
|
|
kubectl wait --for=condition=ready pod --all --timeout=300s
|
|
}
|
|
|
|
waitUntilReadyMicrok8s(){
|
|
echo "Waiting until ready..."
|
|
microk8s kubectl wait --for=condition=ready pod --all --timeout=300s
|
|
}
|
|
|
|
reset(){
|
|
echo "Stopping all crawls & profile browsers"
|
|
kubectl delete cjs -n crawlers --all
|
|
kubectl delete pjs -n crawlers --all
|
|
|
|
echo "Uninstalling..."
|
|
helm uninstall btrix
|
|
|
|
echo "Deleting data..."
|
|
kubectl delete pvc --all
|
|
kubectl delete cronjob -n crawlers --all
|
|
kubectl delete configmap -n crawlers -l btrix.crawlconfig
|
|
}
|
|
|
|
resetMicrok8s(){
|
|
echo "Stopping all crawls & profile browsers"
|
|
microk8s kubectl delete cjs -n crawlers --all
|
|
microk8s kubectl delete pjs -n crawlers --all
|
|
|
|
echo "Uninstalling..."
|
|
microk8s helm uninstall btrix
|
|
|
|
echo "Deleting data..."
|
|
microk8s kubectl delete pvc --all
|
|
microk8s kubectl delete cronjob -n crawlers --all
|
|
microk8s kubectl delete configmap -n crawlers -l btrix.crawlconfig
|
|
}
|
|
|
|
runTests() {
|
|
echo "Running backend tests..."
|
|
python3 -m pytest backend/test/test_*.py
|
|
}
|
|
|
|
runNightlyTests() {
|
|
echo "Running nightly backend tests..."
|
|
python3 -m pytest backend/test_nightly/test_*.py
|
|
}
|
|
|
|
setupLocalConfig() {
|
|
if [ -f ./chart/local.yaml ]; then
|
|
echo "Local config file already exists at ./chart/local.yaml"
|
|
exit 1
|
|
fi
|
|
echo "Copying local example config to ./chart/local.yaml"
|
|
cp ./chart/examples/local-config.yaml ./chart/local.yaml
|
|
echo "Local config file created. Edit ./chart/local.yaml to set local overrides"
|
|
exit 0
|
|
}
|
|
|
|
CONTEXT=$(cat ~/.kube/config | grep "current-context:" | sed "s/current-context: //")
|
|
MICROK8S="-microk8s"
|
|
WAIT="-wait"
|
|
|
|
if [ $CONTEXT != "docker-desktop" ]; then
|
|
echo "Attempting to modify context other than docker-desktop not supported. Quitting."
|
|
exit 1
|
|
fi
|
|
|
|
if [[ $1 = "setup" ]]; then
|
|
setupLocalConfig
|
|
fi
|
|
|
|
if [ ! -f ./chart/local.yaml ]; then
|
|
echo "Local config file not found. Run './btrix setup' to configure"
|
|
exit 1
|
|
fi
|
|
|
|
# bootstrap: build frontend and backend, upgrade and wait until ready
|
|
if [[ $1 = "bootstrap" ]]; then
|
|
|
|
echo "Current context: $CONTEXT"
|
|
echo "Are you sure you want to update this context?"
|
|
if [[ "$(read -e -p '[y/N] > '; echo $REPLY)" == [Yy]* ]] ; then
|
|
echo Continuing
|
|
else
|
|
echo Stopping
|
|
exit 1
|
|
fi
|
|
|
|
if [[ $2 = "$MICROK8S" || $3 = "$MICROK8S" ]] ; then
|
|
bootstrapMicrok8s
|
|
else
|
|
bootstrap
|
|
fi
|
|
|
|
|
|
if [[ $2 = "$WAIT" || $3 = "$WAIT" ]]; then
|
|
if [[ $2 = "$MICROK8S" || $3 = "$MICROK8S" ]] ; then
|
|
waitUntilReadyMicrok8s
|
|
else
|
|
waitUntilReady
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
# reset: uninstall, delete data, then bootstrap
|
|
if [[ $1 = "reset" ]]; then
|
|
|
|
echo "Current context: $CONTEXT"
|
|
echo "Resetting k8s cluster will delete the database. All running crawls will first be canceled. Are you sure you want to do this?"
|
|
if [[ "$(read -e -p '[y/N] > '; echo $REPLY)" == [Yy]* ]] ; then
|
|
echo Continuing
|
|
else
|
|
echo Stopping
|
|
exit 1
|
|
fi
|
|
|
|
if [[ $2 = "$MICROK8S" || $3 = "$MICROK8S" ]] ; then
|
|
resetMicrok8s
|
|
bootstrapMicrok8s
|
|
else
|
|
reset
|
|
bootstrap
|
|
fi
|
|
|
|
if [[ $2 = "$WAIT" || $3 = "$WAIT" ]] ; then
|
|
if [[ $2 = "$MICROK8S" || $3 = "$MICROK8S" ]] ; then
|
|
waitUntilReadyMicrok8s
|
|
else
|
|
waitUntilReady
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
# test: run backend tests
|
|
if [[ $1 = "test" ]]; then
|
|
runTests
|
|
fi
|
|
|
|
# nightly: run nightly backend tests
|
|
if [[ $1 = "nightly" ]]; then
|
|
runNightlyTests
|
|
fi
|
|
|
|
# down: stop and uninstall browsertrix
|
|
if [[ $1 = "down" ]]; then
|
|
if [[ $2 = "$MICROK8S" ]] ; then
|
|
resetMicrok8s
|
|
else
|
|
reset
|
|
fi
|
|
fi
|
|
|
|
echo "Done"
|