blob: f95170021a9f7dd421fe3bea6c7afe9c0aec3471 [file] [log] [blame]
#!/bin/bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with this
# work for additional information regarding copyright ownership. The ASF
# licenses this file to You 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.
#
set -ev
HOME_DIR=$(pwd)
TRAVIS_DIR=$(dirname $0)
BASE_DIR=$1
BACKEND=$2
JACOCO_PORT=$3
JACOCO_DIR=${HOME_DIR}/${TRAVIS_DIR}
JACOCO_JAR=${JACOCO_DIR}/jacocoagent.jar
BIN=$BASE_DIR/bin
CONF=$BASE_DIR/conf/graphs/hugegraph.properties
REST_CONF=$BASE_DIR/conf/rest-server.properties
GREMLIN_CONF=$BASE_DIR/conf/gremlin-server.yaml
. ${BIN}/util.sh
declare -A backend_serializer_map=(["memory"]="text" \
["cassandra"]="cassandra" \
["scylladb"]="scylladb" \
["mysql"]="mysql" \
["hbase"]="hbase" \
["rocksdb"]="binary" \
["postgresql"]="postgresql")
SERIALIZER=${backend_serializer_map[$BACKEND]}
# Set backend and serializer
sed -i "s/backend=.*/backend=$BACKEND/" $CONF
sed -i "s/serializer=.*/serializer=$SERIALIZER/" $CONF
# Set PostgreSQL configurations if needed
if [ "$BACKEND" == "postgresql" ]; then
sed -i '/org.postgresql.Driver/,+2 s/\#//g' $CONF
fi
# Set timeout for hbase
if [ "$BACKEND" == "hbase" ]; then
sed -i '$arestserver.request_timeout=200' $REST_CONF
sed -i '$agremlinserver.timeout=200' $REST_CONF
sed -i 's/evaluationTimeout.*/evaluationTimeout: 200000/' $GREMLIN_CONF
fi
# Append schema.sync_deletion=true to config file
echo "schema.sync_deletion=true" >> $CONF
JACOCO_OPTION=""
if [ -n "$JACOCO_PORT" ]; then
if [[ ! -e "${JACOCO_JAR}" ]]; then
download "${JACOCO_DIR}" "https://github.com/apache/hugegraph-doc/raw/binary-1.0/dist/server/jacocoagent.jar"
fi
JACOCO_OPTION="-javaagent:${JACOCO_JAR}=includes=*,port=${JACOCO_PORT},destfile=jacoco-it.exec,output=tcpserver"
fi
echo -e "pa" | $BIN/init-store.sh && $BIN/start-hugegraph.sh -j "$JACOCO_OPTION" -t 60 -v