2024-05-21 23:03:33 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
#set -x
|
|
|
|
|
2024-05-21 23:03:33 +02:00
|
|
|
if test -f .env; then
|
|
|
|
echo "Using .env file"
|
|
|
|
. $(pwd)/.env
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
echo "I am a lite-protocol-tester node"
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
BINARY_PATH=$1
|
2024-05-21 23:03:33 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ ! -x "${BINARY_PATH}" ]; then
|
|
|
|
echo "Invalid binary path '${BINARY_PATH}'. Failing"
|
|
|
|
exit 1
|
|
|
|
fi
|
2024-05-21 23:03:33 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ "${2}" = "--help" ]; then
|
|
|
|
echo "You might want to check nwaku/apps/liteprotocoltester/README.md"
|
|
|
|
exec "${BINARY_PATH}" --help
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
FUNCTION=$2
|
|
|
|
if [ "${FUNCTION}" = "SENDER" ]; then
|
|
|
|
FUNCTION=--test-func=SENDER
|
|
|
|
SERVICENAME=lightpush-service
|
|
|
|
fi
|
2024-05-21 23:03:33 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ "${FUNCTION}" = "RECEIVER" ]; then
|
|
|
|
FUNCTION=--test-func=RECEIVER
|
|
|
|
SERVICENAME=filter-service
|
|
|
|
fi
|
|
|
|
|
|
|
|
SERIVCE_NODE_ADDR=$3
|
|
|
|
if [ -z "${SERIVCE_NODE_ADDR}" ]; then
|
|
|
|
echo "Service node peer_id provided. Failing"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2024-10-25 22:59:02 +02:00
|
|
|
SELECTOR=$4
|
|
|
|
if [ -z "${SELECTOR}" ] || [ "${SELECTOR}" = "SERVICE" ]; then
|
|
|
|
SERVICE_NODE_DIRECT=true
|
|
|
|
elif [ "${SELECTOR}" = "BOOTSTRAP" ]; then
|
|
|
|
SERVICE_NODE_DIRECT=false
|
|
|
|
else
|
|
|
|
echo "Invalid selector '${SELECTOR}'. Failing"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
DO_DETECT_SERVICENODE=0
|
|
|
|
|
|
|
|
if [ "${SERIVCE_NODE_ADDR}" = "servicenode" ]; then
|
|
|
|
DO_DETECT_SERVICENODE=1
|
|
|
|
SERIVCE_NODE_ADDR=""
|
|
|
|
SERVICENAME=servicenode
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "${SERIVCE_NODE_ADDR}" = "waku-sim" ]; then
|
|
|
|
DO_DETECT_SERVICENODE=1
|
|
|
|
SERIVCE_NODE_ADDR=""
|
2024-09-04 08:35:51 +02:00
|
|
|
MY_EXT_IP=$(ip a | grep "inet " | grep -Fv 127.0.0.1 | sed 's/.*inet \([^/]*\).*/\1/')
|
|
|
|
else
|
|
|
|
MY_EXT_IP=$(wget -qO- --no-check-certificate https://api4.ipify.org)
|
2024-08-21 14:54:18 +02:00
|
|
|
fi
|
|
|
|
|
2024-09-04 08:35:51 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ $DO_DETECT_SERVICENODE -eq 1 ]; then
|
2024-09-04 08:35:51 +02:00
|
|
|
RETRIES=${RETRIES:=20}
|
2024-08-21 14:54:18 +02:00
|
|
|
|
|
|
|
while [ -z "${SERIVCE_NODE_ADDR}" ] && [ ${RETRIES} -ge 0 ]; do
|
|
|
|
SERVICE_DEBUG_INFO=$(wget -qO- http://${SERVICENAME}:8645/debug/v1/info --header='Content-Type:application/json' 2> /dev/null);
|
|
|
|
echo "SERVICE_DEBUG_INFO: ${SERVICE_DEBUG_INFO}"
|
|
|
|
|
|
|
|
SERIVCE_NODE_ADDR=$(wget -qO- http://${SERVICENAME}:8645/debug/v1/info --header='Content-Type:application/json' 2> /dev/null | sed 's/.*"listenAddresses":\["\([^"]*\)".*/\1/');
|
|
|
|
echo "Service node not ready, retrying (retries left: ${RETRIES})"
|
2024-09-04 08:35:51 +02:00
|
|
|
sleep 3
|
2024-08-21 14:54:18 +02:00
|
|
|
RETRIES=$(( $RETRIES - 1 ))
|
|
|
|
done
|
|
|
|
|
|
|
|
fi
|
2024-05-21 23:03:33 +02:00
|
|
|
|
|
|
|
if [ -z "${SERIVCE_NODE_ADDR}" ]; then
|
|
|
|
echo "Could not get SERIVCE_NODE_ADDR and none provided. Failing"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2024-10-25 22:59:02 +02:00
|
|
|
if $SERVICE_NODE_DIRECT; then
|
|
|
|
FULL_NODE=--service-node="${SERIVCE_NODE_ADDR}"
|
|
|
|
else
|
|
|
|
FULL_NODE=--bootstrap-node="${SERIVCE_NODE_ADDR}"
|
|
|
|
fi
|
|
|
|
|
2024-05-21 23:03:33 +02:00
|
|
|
if [ -n "${PUBSUB}" ]; then
|
|
|
|
PUBSUB=--pubsub-topic="${PUBSUB}"
|
2024-08-21 14:54:18 +02:00
|
|
|
else
|
|
|
|
PUBSUB=--pubsub-topic="/waku/2/rs/66/0"
|
2024-05-21 23:03:33 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -n "${CONTENT_TOPIC}" ]; then
|
|
|
|
CONTENT_TOPIC=--content-topic="${CONTENT_TOPIC}"
|
|
|
|
fi
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ -n "${CLUSTER_ID}" ]; then
|
|
|
|
CLUSTER_ID=--cluster-id="${CLUSTER_ID}"
|
|
|
|
fi
|
2024-05-21 23:03:33 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ -n "${START_PUBLISHING_AFTER}" ]; then
|
|
|
|
START_PUBLISHING_AFTER=--start-publishing-after="${START_PUBLISHING_AFTER}"
|
|
|
|
fi
|
2024-05-21 23:03:33 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ -n "${MIN_MESSAGE_SIZE}" ]; then
|
|
|
|
MIN_MESSAGE_SIZE=--min-test-msg-size="${MIN_MESSAGE_SIZE}"
|
|
|
|
fi
|
2024-05-21 23:03:33 +02:00
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ -n "${MAX_MESSAGE_SIZE}" ]; then
|
|
|
|
MAX_MESSAGE_SIZE=--max-test-msg-size="${MAX_MESSAGE_SIZE}"
|
2024-05-21 23:03:33 +02:00
|
|
|
fi
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
|
|
|
|
if [ -n "${NUM_MESSAGES}" ]; then
|
|
|
|
NUM_MESSAGES=--num-messages="${NUM_MESSAGES}"
|
2024-05-21 23:03:33 +02:00
|
|
|
fi
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
if [ -n "${DELAY_MESSAGES}" ]; then
|
|
|
|
DELAY_MESSAGES=--delay-messages="${DELAY_MESSAGES}"
|
2024-05-21 23:03:33 +02:00
|
|
|
fi
|
|
|
|
|
2024-08-21 14:54:18 +02:00
|
|
|
echo "Running binary: ${BINARY_PATH}"
|
|
|
|
echo "Tester node: ${FUNCTION}"
|
2024-05-21 23:03:33 +02:00
|
|
|
echo "Using service node: ${SERIVCE_NODE_ADDR}"
|
2024-09-04 08:35:51 +02:00
|
|
|
echo "My external IP: ${MY_EXT_IP}"
|
2024-08-21 14:54:18 +02:00
|
|
|
|
|
|
|
exec "${BINARY_PATH}"\
|
|
|
|
--log-level=INFO\
|
2024-09-04 08:35:51 +02:00
|
|
|
--nat=extip:${MY_EXT_IP}\
|
2024-10-25 22:59:02 +02:00
|
|
|
${FULL_NODE}\
|
2024-08-21 14:54:18 +02:00
|
|
|
${DELAY_MESSAGES}\
|
|
|
|
${NUM_MESSAGES}\
|
2024-05-21 23:03:33 +02:00
|
|
|
${PUBSUB}\
|
|
|
|
${CONTENT_TOPIC}\
|
2024-08-21 14:54:18 +02:00
|
|
|
${CLUSTER_ID}\
|
|
|
|
${FUNCTION}\
|
|
|
|
${START_PUBLISHING_AFTER}\
|
|
|
|
${MIN_MESSAGE_SIZE}\
|
|
|
|
${MAX_MESSAGE_SIZE}
|
2024-05-21 23:03:33 +02:00
|
|
|
# --config-file=config.toml\
|