4 DOCKER=`which docker.io`
6 if [[ "$DOCKER" == "" ]]; then
12 echo >&2 "usage: $0 (start|stop|restart|test) [options]"
14 echo >&2 "$0 start/stop/restart options:"
15 echo >&2 " -d [port], --doc[=port] Documentation server (default port 9898)"
16 echo >&2 " -w [port], --workbench[=port] Workbench server (default port 9899)"
17 echo >&2 " -s [port], --sso[=port] SSO server (default port 9901)"
18 echo >&2 " -a [port], --api[=port] API server (default port 9900)"
19 echo >&2 " -k, --keep Keep servers"
20 echo >&2 " --ssh Enable SSH access to server containers"
21 echo >&2 " -h, --help Display this help and exit"
23 echo >&2 " If no options are given, the action is applied to all servers."
25 echo >&2 "$0 test [testname] [testname] ..."
26 echo >&2 " By default, all tests are run."
31 echo `$DOCKER inspect $container |grep IPAddress |cut -f4 -d\"`
34 function start_container {
36 if [[ "$1" != '' ]]; then
40 if [[ "$2" != '' ]]; then
42 args="$args --name $name"
44 if [[ "$3" != '' ]]; then
46 args="$args -v $volume"
48 if [[ "$4" != '' ]]; then
50 args="$args --link $link"
56 args="$args -e ENABLE_SSH=$ENABLE_SSH"
59 `$DOCKER ps |grep -P "$name[^/]" -q`
60 if [[ "$?" == "0" ]]; then
61 echo "You have a running container with name $name -- skipping."
65 # Remove any existing container by this name.
66 $DOCKER rm "$name" 2>/dev/null
68 echo "Starting container:"
69 echo " $DOCKER run $args $image"
70 container=`$DOCKER run $args $image`
71 if [[ "$?" != "0" ]]; then
72 echo "Unable to start container"
77 ip=$(ip_address $container )
79 echo "You can ssh into the container with:"
86 declare -a keep_volumes
88 # Initialize the global `keep_volumes' array. If any keep volumes
89 # already appear to exist (mounted volumes with a top-level "keep"
90 # directory), use them; create temporary volumes if necessary.
92 function make_keep_volumes () {
93 # Mount a keep volume if we don't already have one
94 for mountpoint in $(cut -d ' ' -f 2 /proc/mounts); do
95 if [[ -d "$mountpoint/keep" && "$mountpoint" != "/" ]]; then
96 keep_volumes+=($mountpoint)
100 # Create any keep volumes that do not yet exist.
101 while [ ${#keep_volumes[*]} -lt 2 ]
103 new_keep=$(mktemp -d)
104 echo >&2 "mounting 512M tmpfs keep volume in $new_keep"
105 sudo mount -t tmpfs -o size=512M tmpfs $new_keep
107 keep_volumes+=($new_keep)
112 local start_doc=false
113 local start_sso=false
114 local start_api=false
115 local start_workbench=false
116 local start_keep=false
118 # NOTE: This requires GNU getopt (part of the util-linux package on Debian-based distros).
119 local TEMP=`getopt -o d::s::a::w::kh \
120 --long doc::,sso::,api::,workbench::,keep,help,ssh \
123 if [ $? != 0 ] ; then echo "Use -h for help"; exit 1 ; fi
125 # Note the quotes around `$TEMP': they are essential!
133 "") start_doc=9898; shift 2 ;;
134 *) start_doc=$2; shift 2 ;;
139 "") start_sso=9901; shift 2 ;;
140 *) start_sso=$2; shift 2 ;;
145 "") start_api=9900; shift 2 ;;
146 *) start_api=$2; shift 2 ;;
151 "") start_workbench=9899; shift 2 ;;
152 *) start_workbench=$2; shift 2 ;;
160 # ENABLE_SSH is a global variable
175 # If no options were selected, then start all servers.
176 if [[ $start_doc == false &&
177 $start_sso == false &&
178 $start_api == false &&
179 $start_workbench == false &&
180 $start_keep == false ]]
189 if [[ $start_doc != false ]]
191 start_container "9898:80" "doc_server" '' '' "arvados/doc"
194 if [[ $start_sso != false ]]
196 start_container "9901:443" "sso_server" '' '' "arvados/sso"
199 if [[ $start_api != false ]]
201 start_container "9900:443" "api_server" '' "sso_server:sso" "arvados/api"
204 if [[ $start_workbench != false ]]
206 start_container "9899:80" "workbench_server" '' "api_server:api" "arvados/workbench"
209 if [[ $start_keep != false ]]
211 # create `keep_volumes' array with a list of keep mount points
212 # remove any stale metadata from those volumes before starting them
214 for v in ${keep_volumes[*]}
216 [ -f $v/keep/.metadata.yml ] && sudo rm $v/keep/.metadata.yml
218 start_container "25107:25107" "keep_server_0" \
219 "${keep_volumes[0]}:/dev/keep-0" \
222 start_container "25108:25107" "keep_server_1" \
223 "${keep_volumes[1]}:/dev/keep-0" \
228 if [ -d $HOME/.config/arvados ] || mkdir -p $HOME/.config/arvados
230 cat >$HOME/.config/arvados/settings.conf <<EOF
231 ARVADOS_API_HOST=$(ip_address "api_server")
232 ARVADOS_API_HOST_INSECURE=yes
233 ARVADOS_API_TOKEN=$(cat api/generated/superuser_token)
242 local stop_workbench=""
245 # NOTE: This requires GNU getopt (part of the util-linux package on Debian-based distros).
246 local TEMP=`getopt -o d::s::a::w::kh \
247 --long doc::,sso::,api::,workbench::,keep,help,ssh \
250 if [ $? != 0 ] ; then echo "Use -h for help"; exit 1 ; fi
252 # Note the quotes around `$TEMP': they are essential!
259 stop_doc=doc_server ; shift 2 ;;
261 stop_sso=sso_server ; shift 2 ;;
263 stop_api=api_server ; shift 2 ;;
265 stop_workbench=workbench_server ; shift 2 ;;
267 stop_keep="keep_server_0 keep_server_1" ; shift ;;
282 # If no options were selected, then start all servers.
283 if [[ $stop_doc == "" &&
286 $stop_workbench == "" &&
292 stop_workbench=workbench_server
293 stop_keep="keep_server_0 keep_server_1"
296 $DOCKER stop $stop_doc $stop_sso $stop_api $stop_workbench $stop_keep \
304 alltests="python-sdk api"
309 for testname in $alltests
311 echo "testing $testname..."
314 do_start --api --keep --sso
315 export ARVADOS_API_HOST=$(ip_address "api_server")
316 export ARVADOS_API_HOST_INSECURE=yes
317 export ARVADOS_API_TOKEN=$(cat api/generated/superuser_token)
318 python -m unittest discover ../sdk/python
321 $DOCKER run -t -i arvados/api \
322 /usr/src/arvados/services/api/script/rake_test.sh
325 echo >&2 "unknown test $testname"