2021-09-27 13:10:35 +00:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
#
|
|
|
|
# PASST - Plug A Simple Socket Transport
|
|
|
|
# for qemu/UNIX domain socket mode
|
|
|
|
#
|
|
|
|
# PASTA - Pack A Subtle Tap Abstraction
|
|
|
|
# for network namespace/tap device mode
|
|
|
|
#
|
|
|
|
# test/lib/layout - tmux pane layouts
|
|
|
|
#
|
|
|
|
# Copyright (c) 2021 Red Hat GmbH
|
|
|
|
# Author: Stefano Brivio <sbrivio@redhat.com>
|
|
|
|
|
|
|
|
# layout_host() - Simple host commands layout with info and host panes
|
|
|
|
layout_host() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
tmux kill-pane -a -t 0
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -h -l '35%' -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_HOST=0
|
|
|
|
PANE_INFO=1
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T "test log"
|
|
|
|
|
2022-09-12 10:56:18 +00:00
|
|
|
if context_exists host; then
|
|
|
|
pane_watch_contexts 0 host host
|
|
|
|
else
|
|
|
|
tmux pipe-pane -O -t ${PANE_HOST} "cat >> ${LOGDIR}/pane_host.log"
|
|
|
|
tmux select-pane -t ${PANE_HOST} -T "host"
|
|
|
|
fi
|
2021-09-27 13:10:35 +00:00
|
|
|
|
|
|
|
info_layout "host commands only"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
test: Add log file tests for pasta plus corresponding layout and setup
To test log files on a tmpfs mount, we need to unshare the mount
namespace, which means using a context for the passt pane is not
really practical at the moment, as we can't open a shell there, so
we would have to encapsulate all the commands under 'unshare -rUm',
plus the "inner" pasta command, running in turn a tcp_rr server.
It might be worth fixing this by e.g. detecting we are trying to
spawn an interactive shell and adding a special path in the context
setup with some form of stdin redirection -- I'm not sure it's doable
though.
For this reason, add a new layout, using a context only for the host
pane, while keeping the old command dispatch mechanism for the passt
pane.
We also need a new setup function that doesn't start pasta: we want
to start and restart it with different options.
Further, we need a 'pint' directive, to send an interrupt to the
passt pane: add that in lib/test.
All the tests before the one involving tmpfs and a detached mount
namespace were also tested with the context mechanism. To make an
eventual conversion easier, pass tcp_crr directly as a command on
pasta's command line where feasible.
While at it, fix the comment to the teardown_pasta() function.
The new test set can be semi-conveniently run as:
./run pasta_options/log_to_file
and it checks basic log creation, size of the log file after flooding
it with debug entries, rotations, and basic consistency after
rotations, on both an existing filesystem and a tmpfs, chosen as
it doesn't support collapsing data ranges via fallocate(), hence
triggering the fall-back mechanism for logging rotation.
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
2022-10-07 00:16:08 +00:00
|
|
|
# layout_pasta_simple() - Panes for host and pasta
|
|
|
|
layout_pasta_simple() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
tmux kill-pane -a -t 0
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
|
|
|
|
PANE_PASST=0
|
|
|
|
PANE_HOST=1
|
|
|
|
PANE_INFO=2
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T "test log"
|
|
|
|
|
|
|
|
if context_exists host; then
|
|
|
|
pane_watch_contexts ${PANE_HOST} host host
|
|
|
|
else
|
|
|
|
tmux pipe-pane -O -t ${PANE_HOST} "cat >> ${LOGDIR}/pane_host.log"
|
|
|
|
tmux select-pane -t ${PANE_HOST} -T "host"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if context_exists passt; then
|
|
|
|
pane_watch_contexts ${PANE_PASST} host host
|
|
|
|
else
|
|
|
|
tmux pipe-pane -O -t ${PANE_PASST} "cat >> ${LOGDIR}/pane_passt.log"
|
|
|
|
tmux select-pane -t ${PANE_PASST} -T "pasta"
|
|
|
|
fi
|
|
|
|
|
|
|
|
info_layout "single pasta instance"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
2021-09-27 13:10:35 +00:00
|
|
|
# layout_pasta() - Panes for host, pasta, and separate one for namespace
|
|
|
|
layout_pasta() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
tmux kill-pane -a -t 0
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
tmux split-window -h -l '42%' -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_NS=0
|
|
|
|
PANE_INFO=1
|
|
|
|
PANE_HOST=2
|
|
|
|
PANE_PASST=3
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T "test log"
|
|
|
|
|
2022-09-12 10:56:18 +00:00
|
|
|
pane_watch_contexts ${PANE_HOST} host host
|
2022-09-12 10:56:19 +00:00
|
|
|
pane_watch_contexts ${PANE_PASST} pasta passt
|
2022-09-12 10:56:21 +00:00
|
|
|
pane_watch_contexts ${PANE_NS} "namespace" unshare ns
|
2021-09-27 13:10:35 +00:00
|
|
|
|
|
|
|
info_layout "single pasta instance with namespace"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# layout_passt() - Panes for host, passt, and guest
|
|
|
|
layout_passt() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
tmux kill-pane -a -t 0
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
tmux split-window -h -l '42%' -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_GUEST=0
|
|
|
|
PANE_INFO=1
|
|
|
|
PANE_HOST=2
|
|
|
|
PANE_PASST=3
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T "test log"
|
|
|
|
|
2022-09-12 10:56:18 +00:00
|
|
|
pane_watch_contexts ${PANE_HOST} host host
|
2022-09-12 10:56:19 +00:00
|
|
|
pane_watch_contexts ${PANE_PASST} passt passt
|
2022-09-12 10:56:22 +00:00
|
|
|
pane_watch_contexts ${PANE_GUEST} guest qemu guest
|
2021-09-27 13:10:35 +00:00
|
|
|
|
|
|
|
info_layout "single passt instance with guest"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# layout_passt_in_pasta() - Host, passt within pasta, namespace and guest
|
|
|
|
layout_passt_in_pasta() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
tmux kill-pane -a -t 0
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -l '45%' -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
tmux split-window -h -l '42%' -t passt_test:1.0
|
|
|
|
tmux split-window -v -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_GUEST=0
|
|
|
|
PANE_NS=1
|
|
|
|
PANE_INFO=2
|
|
|
|
PANE_HOST=3
|
|
|
|
PANE_PASST=4
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
2022-09-12 10:56:24 +00:00
|
|
|
pane_watch_contexts ${PANE_GUEST} "guest" qemu guest
|
|
|
|
pane_watch_contexts ${PANE_NS} "namespace" ns
|
2021-09-27 13:10:35 +00:00
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T "test log"
|
|
|
|
|
2022-09-12 10:56:18 +00:00
|
|
|
pane_watch_contexts ${PANE_HOST} host host
|
2021-09-27 13:10:35 +00:00
|
|
|
|
2022-09-12 10:56:24 +00:00
|
|
|
pane_watch_contexts ${PANE_PASST} "passt in pasta (namespace)" pasta passt
|
2021-09-27 13:10:35 +00:00
|
|
|
|
|
|
|
info_layout "passt and guest in namespace, connected by pasta"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# layout_two_guests() - Two guest panes, two passt panes, plus host and log
|
|
|
|
layout_two_guests() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
tmux kill-pane -a -t 0
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -t passt_test
|
|
|
|
tmux split-window -h -l '33%'
|
|
|
|
tmux split-window -h -t passt_test:1.1
|
|
|
|
|
|
|
|
tmux split-window -h -l '35%' -t passt_test:1.0
|
|
|
|
tmux split-window -v -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_GUEST_1=0
|
|
|
|
PANE_GUEST_2=1
|
|
|
|
PANE_INFO=2
|
|
|
|
PANE_HOST=3
|
|
|
|
PANE_PASST_1=4
|
|
|
|
PANE_PASST_2=5
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
2022-09-12 10:56:23 +00:00
|
|
|
pane_watch_contexts ${PANE_GUEST_1} "guest #1 in namespace #1" qemu_1 guest_1
|
|
|
|
pane_watch_contexts ${PANE_GUEST_2} "guest #2 in namespace #2" qemu_2 guest_2
|
2021-09-27 13:10:35 +00:00
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T "test log"
|
|
|
|
|
2022-09-12 10:56:18 +00:00
|
|
|
pane_watch_contexts ${PANE_HOST} host host
|
2022-09-12 10:56:23 +00:00
|
|
|
pane_watch_contexts ${PANE_PASST_1} "passt #1 in namespace #1" pasta_1 passt_1
|
|
|
|
pane_watch_contexts ${PANE_PASST_2} "passt #2 in namespace #2" pasta_2 passt_2
|
2021-09-27 13:10:35 +00:00
|
|
|
|
|
|
|
info_layout "two guests, two passt instances, in namespaces"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# layout_demo_pasta() - Four panes for pasta demo
|
|
|
|
layout_demo_pasta() {
|
|
|
|
sleep 3
|
|
|
|
|
2021-09-29 14:45:26 +00:00
|
|
|
cmd_write 0 cd ${BASEPATH}
|
2021-09-27 13:10:35 +00:00
|
|
|
cmd_write 0 clear
|
|
|
|
sleep 1
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
tmux split-window -h -l '42%' -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_NS=0
|
|
|
|
PANE_INFO=1
|
|
|
|
PANE_HOST=2
|
|
|
|
PANE_PASST=3
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_NS} "cat >> ${LOGDIR}/pane_ns.log"
|
|
|
|
tmux select-pane -t ${PANE_NS} -T "namespace"
|
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T ""
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_HOST} "cat >> ${LOGDIR}/pane_host.log"
|
|
|
|
tmux select-pane -t ${PANE_HOST} -T "host"
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_PASST} "cat >> ${LOGDIR}/pane_passt.log"
|
|
|
|
tmux select-pane -t ${PANE_PASST} -T "pasta"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# layout_demo_passt() - Four panes for passt demo
|
|
|
|
layout_demo_passt() {
|
|
|
|
sleep 3
|
|
|
|
|
2021-09-29 14:45:26 +00:00
|
|
|
cmd_write 0 cd ${BASEPATH}
|
2021-09-27 13:10:35 +00:00
|
|
|
cmd_write 0 clear
|
|
|
|
sleep 1
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
tmux split-window -h -l '42%' -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_GUEST=0
|
|
|
|
PANE_INFO=1
|
|
|
|
PANE_HOST=2
|
|
|
|
PANE_PASST=3
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_GUEST} "cat >> ${LOGDIR}/pane_guest.log"
|
|
|
|
tmux select-pane -t ${PANE_GUEST} -T "guest"
|
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2021-09-27 13:10:35 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T ""
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_HOST} "cat >> ${LOGDIR}/pane_host.log"
|
|
|
|
tmux select-pane -t ${PANE_HOST} -T "host"
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_PASST} "cat >> ${LOGDIR}/pane_passt.log"
|
|
|
|
tmux select-pane -t ${PANE_PASST} -T "passt in pasta (namespace)"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
2022-02-21 12:35:45 +00:00
|
|
|
|
|
|
|
# layout_demo_podman() - Four panes for pasta demo with Podman
|
|
|
|
layout_demo_podman() {
|
|
|
|
sleep 3
|
|
|
|
|
|
|
|
cmd_write 0 cd ${BASEPATH}
|
|
|
|
cmd_write 0 clear
|
|
|
|
sleep 1
|
|
|
|
cmd_write 0 clear
|
|
|
|
|
|
|
|
tmux split-window -v -l '65%' -t passt_test
|
|
|
|
tmux split-window -h -t passt_test
|
|
|
|
tmux split-window -h -l '42%' -t passt_test:1.0
|
|
|
|
|
|
|
|
PANE_HOST=0
|
|
|
|
PANE_INFO=1
|
|
|
|
PANE_NS1=2
|
|
|
|
PANE_NS2=3
|
|
|
|
|
|
|
|
get_info_cols
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_NS1} "cat >> ${LOGDIR}/pane_ns1.log"
|
|
|
|
tmux select-pane -t ${PANE_NS1} -T "Podman with slirp4netns"
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_NS2} "cat >> ${LOGDIR}/pane_ns2.log"
|
|
|
|
tmux select-pane -t ${PANE_NS2} -T "Podman with pasta"
|
|
|
|
|
2022-09-13 04:35:20 +00:00
|
|
|
tmux send-keys -l -t ${PANE_INFO} 'while cat '"$STATEBASE/log_pipe"'; do :; done'
|
2022-02-21 12:35:45 +00:00
|
|
|
tmux send-keys -t ${PANE_INFO} -N 100 C-m
|
|
|
|
tmux select-pane -t ${PANE_INFO} -T ""
|
|
|
|
|
|
|
|
tmux pipe-pane -O -t ${PANE_HOST} "cat >> ${LOGDIR}/pane_host.log"
|
|
|
|
tmux select-pane -t ${PANE_HOST} -T "host"
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|