2018-11-11 08:13:20 -08:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -e
|
2018-10-02 20:51:19 -07:00
|
|
|
|
2018-11-30 08:17:28 -08:00
|
|
|
channel=$(
|
|
|
|
cd "$(dirname "$0")";
|
|
|
|
node -p '
|
2019-02-17 09:46:54 -08:00
|
|
|
let p = [
|
|
|
|
"../lib/node_modules/@solana/web3.js/package.json",
|
|
|
|
"../@solana/web3.js/package.json",
|
|
|
|
"../package.json"
|
|
|
|
].find(require("fs").existsSync);
|
|
|
|
if (!p) throw new Error("Unable to locate solana-web3.js directory");
|
2018-12-19 19:28:28 -08:00
|
|
|
p["testnetDefaultChannel"]
|
2018-11-30 08:17:28 -08:00
|
|
|
'
|
|
|
|
)
|
2018-11-30 07:49:40 -08:00
|
|
|
|
2018-10-02 20:51:19 -07:00
|
|
|
usage() {
|
|
|
|
exitcode=0
|
|
|
|
if [[ -n "$1" ]]; then
|
|
|
|
exitcode=1
|
|
|
|
echo "Error: $*"
|
|
|
|
fi
|
|
|
|
cat <<EOF
|
2018-10-13 11:21:20 -07:00
|
|
|
usage: $0 [update|up|down|logs|deploy] [command-specific options]
|
2018-10-02 20:51:19 -07:00
|
|
|
|
|
|
|
Operate a local testnet
|
|
|
|
|
2019-02-15 19:59:42 -08:00
|
|
|
update - Update the image from dockerhub.com
|
2018-10-02 20:51:19 -07:00
|
|
|
up - Start the network
|
|
|
|
down - Stop the network
|
|
|
|
logs - Display network logging
|
2018-10-13 11:21:20 -07:00
|
|
|
deploy - Deploy a native program.
|
2018-10-02 20:51:19 -07:00
|
|
|
|
|
|
|
|
|
|
|
logs-specific options:
|
|
|
|
-f - Follow log output
|
|
|
|
|
2019-02-15 19:59:42 -08:00
|
|
|
update-specific options:
|
|
|
|
edge - Update the "edge" channel image
|
|
|
|
beta - Update the "beta" channel imae
|
|
|
|
|
|
|
|
up-specific options:
|
|
|
|
edge - Start the "edge" channel image
|
|
|
|
beta - Start the "beta" channel image
|
2018-12-10 15:58:05 -07:00
|
|
|
-n - Optional Docker network to join
|
2018-11-30 07:49:40 -08:00
|
|
|
|
|
|
|
Default channel: $channel
|
2018-10-02 20:51:19 -07:00
|
|
|
|
|
|
|
down-specific options:
|
|
|
|
none
|
|
|
|
|
2018-10-13 11:21:20 -07:00
|
|
|
deploy-specific options:
|
|
|
|
program - The program to deploy.
|
|
|
|
|
|
|
|
Note that deployments are discarded on network stop
|
2018-10-02 20:51:19 -07:00
|
|
|
|
|
|
|
EOF
|
|
|
|
exit $exitcode
|
|
|
|
}
|
|
|
|
|
|
|
|
[[ -n $1 ]] || usage
|
|
|
|
cmd="$1"
|
2018-10-02 21:38:02 -07:00
|
|
|
shift
|
2018-10-02 20:51:19 -07:00
|
|
|
|
|
|
|
docker --version || usage "It appears that docker is not installed"
|
|
|
|
case $cmd in
|
|
|
|
update)
|
2018-10-02 21:38:02 -07:00
|
|
|
if [[ -n $1 ]]; then
|
|
|
|
channel="$1"
|
2018-10-02 20:51:19 -07:00
|
|
|
fi
|
|
|
|
[[ $channel = edge || $channel = beta ]] || usage "Invalid channel: $channel"
|
|
|
|
|
|
|
|
(
|
|
|
|
set -x
|
|
|
|
docker pull solanalabs/solana:"$channel"
|
|
|
|
)
|
|
|
|
;;
|
|
|
|
up)
|
2019-02-15 19:59:42 -08:00
|
|
|
while [[ -n $1 ]]; do
|
|
|
|
if [[ $1 = -n ]]; then
|
|
|
|
[[ -n $2 ]] || usage "Invalid $1 argument"
|
|
|
|
network="$2"
|
|
|
|
shift 2
|
|
|
|
elif [[ $1 = edge ]]; then
|
|
|
|
channel=edge
|
|
|
|
shift 1
|
|
|
|
elif [[ $1 = beta ]]; then
|
|
|
|
channel=beta
|
|
|
|
shift 1
|
|
|
|
else
|
|
|
|
usage "Unknown argument: $1"
|
|
|
|
fi
|
|
|
|
done
|
2018-12-10 15:58:05 -07:00
|
|
|
|
2018-10-02 20:51:19 -07:00
|
|
|
(
|
|
|
|
set -x
|
2018-11-27 17:02:55 -08:00
|
|
|
RUST_LOG=${RUST_LOG:-solana=warn,solana_bpf=info,solana_jsonrpc=info,solana::rpc=info,solana_fullnode=info,solana::drone=info,solana::bank=info,solana::banking_stage=info,solana::system_program=info}
|
2018-10-14 13:05:05 -07:00
|
|
|
|
2019-02-15 19:59:42 -08:00
|
|
|
ARGS=(
|
|
|
|
--detach
|
|
|
|
--name solana-localnet
|
|
|
|
--network "$network"
|
|
|
|
--rm
|
|
|
|
--publish 8899:8899
|
|
|
|
--publish 8900:8900
|
|
|
|
--publish 9900:9900
|
|
|
|
--tty
|
|
|
|
--env "RUST_LOG=$RUST_LOG"
|
|
|
|
)
|
|
|
|
|
|
|
|
docker run "${ARGS[@]}" solanalabs/solana:"$channel"
|
2018-10-02 20:51:19 -07:00
|
|
|
|
2018-10-25 18:13:32 -07:00
|
|
|
for _ in 1 2 3 4 5; do
|
|
|
|
if curl \
|
|
|
|
-X POST \
|
|
|
|
-H "Content-Type: application/json" \
|
|
|
|
-d '{"jsonrpc":"2.0","id":1, "method":"getTransactionCount"}' \
|
|
|
|
http://localhost:8899; then
|
|
|
|
break;
|
|
|
|
fi
|
|
|
|
sleep 1
|
|
|
|
done
|
2018-10-02 20:51:19 -07:00
|
|
|
)
|
|
|
|
;;
|
|
|
|
down)
|
|
|
|
(
|
|
|
|
set -x
|
2018-12-11 14:08:36 -08:00
|
|
|
if [[ -n "$(docker ps --filter "name=^solana-localnet$" -q)" ]]; then
|
|
|
|
docker stop --time 0 solana-localnet
|
|
|
|
fi
|
2018-10-02 20:51:19 -07:00
|
|
|
)
|
|
|
|
;;
|
|
|
|
logs)
|
2018-10-13 10:54:37 -07:00
|
|
|
follow=false
|
|
|
|
if [[ -n $1 ]]; then
|
|
|
|
if [[ $1 = "-f" ]]; then
|
|
|
|
follow=true
|
|
|
|
else
|
|
|
|
usage "Unknown argument: $1"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
while $follow; do
|
|
|
|
if [[ -n $(docker ps -q -f name=solana-localnet) ]]; then
|
|
|
|
(
|
|
|
|
set -x
|
|
|
|
docker logs solana-localnet -f
|
|
|
|
) || true
|
|
|
|
fi
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
|
2018-10-02 20:51:19 -07:00
|
|
|
(
|
|
|
|
set -x
|
2018-10-13 10:54:37 -07:00
|
|
|
docker logs solana-localnet
|
2018-10-02 20:51:19 -07:00
|
|
|
)
|
|
|
|
;;
|
2018-10-13 11:21:20 -07:00
|
|
|
deploy)
|
|
|
|
program=$1
|
|
|
|
[[ -n $program ]] || usage
|
|
|
|
[[ -f $program ]] || usage "file does not exist: $program"
|
|
|
|
|
|
|
|
basename=$(basename "$program")
|
|
|
|
if docker exec solana-localnet test -f /usr/bin/"$basename"; then
|
|
|
|
echo "Error: $basename has already been deployed"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
(
|
|
|
|
set -x
|
|
|
|
docker cp "$program" solana-localnet:/usr/bin/
|
|
|
|
)
|
|
|
|
docker exec solana-localnet ls -l /usr/bin/"$basename"
|
|
|
|
echo "$basename deployed successfully"
|
|
|
|
;;
|
2018-10-02 20:51:19 -07:00
|
|
|
*)
|
|
|
|
usage "Unknown command: $cmd"
|
|
|
|
esac
|
|
|
|
|
|
|
|
exit 0
|