set -e
sync() {
- if test $NODE = localhost ; then
- # nothing to do
- else
+ if test "$NODE" != localhost ; then
if ! ssh $NODE test -d arvados-setup ; then
ssh $NODE git init --bare arvados-setup.git
if ! git remote add $NODE $DEPLOY_USER@$NODE:arvados-setup.git ; then
git push $NODE $BRANCH
ssh $NODE git -C arvados-setup checkout $BRANCH
ssh $NODE git -C arvados-setup pull
+ fi
}
deploynode() {
fi
}
+loadconfig() {
+ CONFIG_FILE=local.params
+ if ! test -s $CONFIG_FILE ; then
+ echo "Must be run from arvados-setup, maybe you need to 'initialize' first?"
+ fi
+ source ${CONFIG_FILE}
+}
+
subcmd="$1"
if test -n "$subcmd" ; then
shift
;;
deploy)
NODE=$1
- CONFIG_FILE=local.params
- if ! test -s $CONFIG_FILE ; then
- echo "Must be run from arvados-setup, maybe you need to 'initialize' first?"
- fi
- source ${CONFIG_FILE}
+ loadconfig
set -x
sync
deploynode
fi
+
+ ;;
+ diagnostics)
+ loadconfig
+
+ if ! which arvados-client ; then
+ apt-get install arvados-client
+ fi
+
+ export ARVADOS_API_HOST="${CLUSTER}.${DOMAIN}"
+ export ARVADOS_API_TOKEN="$SYSTEM_ROOT_TOKEN"
+
+ arvados-client diagnostics -internal-client
;;
*)
echo "Arvados installer"
echo ""
echo "initialize initialize the setup directory for configuration"
echo "deploy deploy the configuration from the setup directory"
+ echo "diagnostics check your install using diagnostics"
;;
esac