forked from microsoft/msquic
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_endpoint.sh
107 lines (93 loc) · 3.01 KB
/
run_endpoint.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#! /usr/bin/env bash
# Set up the routing needed for the simulation
/setup.sh
if [ -n "$TESTCASE" ]; then
case "$TESTCASE" in
# TODO: add supported test cases here
"versionnegotiation"|"handshake"|"resumption"|"zerortt"|"transfer"|"retry"|"multiconnect"|"keyupdate"|"chacha20")
;;
*)
exit 127
;;
esac
fi
# The following variables are available for use:
# - ROLE contains the role of this execution context, client or server
# - SERVER_PARAMS contains user-supplied command line parameters
# - CLIENT_PARAMS contains user-supplied command line parameters
# Start LTTng live streaming.
echo "Starting LTTng logging..."
lttng -q create msquiclive --live 1000
lttng enable-event --userspace CLOG_*
lttng add-context --userspace --type=vpid --type=vtid
lttng start
babeltrace -i lttng-live net://localhost
babeltrace --names all -i lttng-live net://localhost/host/`hostname`/msquiclive \
| stdbuf -i0 -o0 clog2text_lttng -s clog.sidecar --t --c > /logs/quic.log &
if [ "$ROLE" == "client" ]; then
# Wait for the simulator to start up.
/wait-for-it.sh sim:57832 -s -t 30
cd /downloads || exit
CLIENT_PARAMS="-sslkeylogfile:$SSLKEYLOGFILE $CLIENT_PARAMS"
case "$TESTCASE" in
"resumption")
CLIENT_PARAMS="-test:R $CLIENT_PARAMS"
;;
"versionnegotiation")
CLIENT_PARAMS="-test:V $CLIENT_PARAMS"
;;
"handshake")
CLIENT_PARAMS="-test:H $CLIENT_PARAMS"
;;
"transfer")
CLIENT_PARAMS="-test:D -timeout:50000 $CLIENT_PARAMS"
;;
"multiconnect")
CLIENT_PARAMS="-test:D -timeout:25000 $CLIENT_PARAMS"
;;
"zerortt")
CLIENT_PARAMS="-test:Z $CLIENT_PARAMS"
;;
"keyupdate")
CLIENT_PARAMS="-test:U $CLIENT_PARAMS"
;;
"chacha20")
CLIENT_PARAMS="-test:2 $CLIENT_PARAMS"
;;
*)
CLIENT_PARAMS="-test:D $CLIENT_PARAMS"
;;
esac
# Figure out the server name from the first request. This assumes all URLS
# point to the same server.
REQS=($REQUESTS)
REQ=${REQS[0]}
SERVER=$(echo $REQ | cut -d'/' -f3 | cut -d':' -f1)
echo "Connecting to $SERVER"
echo "Client params (before files):$CLIENT_PARAMS"
if [ "$TESTCASE" == "multiconnect" ]; then
for REQ in $REQUESTS; do
quicinterop ${CLIENT_PARAMS} -custom:$SERVER -port:443 -urls:"$REQ"
done
else
# FIXME: there doesn't seem to be a way to specify to use /certs/ca.pem
# for certificate verification
quicinterop ${CLIENT_PARAMS} -custom:$SERVER -port:443 -urls:${REQUESTS[@]}
fi
# Wait for the logs to flush to disk.
sleep 5
echo "Client complete."
elif [ "$ROLE" == "server" ]; then
case "$TESTCASE" in
"retry")
SERVER_PARAMS="-retry:1 $SERVER_PARAMS"
;;
*)
;;
esac
quicinteropserver ${SERVER_PARAMS} -root:/www -listen:* -port:443 \
-file:/certs/cert.pem -key:/certs/priv.key -noexit &
wait
echo "Server complete."
fi
echo "Script complete."