test/lib: Move screen-scraping setup and layout functions to _ugly files
I'm going to add yet another one of those, for which I have no quick solution. It's a regression in some sense, but at least if we make this regression more observable and defined, it should be easier to find a comprehensive solution later, within this or another testing framework. Signed-off-by: Stefano Brivio <sbrivio@redhat.com> Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
ea5e046646
commit
e76e65a36e
5 changed files with 123 additions and 92 deletions
|
@ -13,75 +13,6 @@
|
||||||
# Copyright (c) 2021 Red Hat GmbH
|
# Copyright (c) 2021 Red Hat GmbH
|
||||||
# Author: Stefano Brivio <sbrivio@redhat.com>
|
# 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
|
|
||||||
|
|
||||||
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 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
|
|
||||||
|
|
||||||
info_layout "host commands only"
|
|
||||||
|
|
||||||
sleep 1
|
|
||||||
}
|
|
||||||
|
|
||||||
# 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
|
|
||||||
}
|
|
||||||
|
|
||||||
# layout_pasta() - Panes for host, pasta, and separate one for namespace
|
# layout_pasta() - Panes for host, pasta, and separate one for namespace
|
||||||
layout_pasta() {
|
layout_pasta() {
|
||||||
sleep 3
|
sleep 3
|
||||||
|
|
83
test/lib/layout_ugly
Normal file
83
test/lib/layout_ugly
Normal file
|
@ -0,0 +1,83 @@
|
||||||
|
#!/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_ugly - screen-scraped tmux pane layouts
|
||||||
|
#
|
||||||
|
# Copyright (c) 2022 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
|
||||||
|
|
||||||
|
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 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
|
||||||
|
|
||||||
|
info_layout "host commands only"
|
||||||
|
|
||||||
|
sleep 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# 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
|
||||||
|
}
|
|
@ -26,11 +26,6 @@ setup_build() {
|
||||||
layout_host
|
layout_host
|
||||||
}
|
}
|
||||||
|
|
||||||
# setup_distro() - Set up pane layout for distro tests
|
|
||||||
setup_distro() {
|
|
||||||
layout_host
|
|
||||||
}
|
|
||||||
|
|
||||||
# setup_passt() - Start qemu and passt
|
# setup_passt() - Start qemu and passt
|
||||||
setup_passt() {
|
setup_passt() {
|
||||||
context_setup_host host
|
context_setup_host host
|
||||||
|
@ -106,13 +101,6 @@ setup_pasta() {
|
||||||
wait_for [ -f "${STATESETUP}/passt.pid" ]
|
wait_for [ -f "${STATESETUP}/passt.pid" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
# setup_pasta_options() - Set up layout and host context without starting pasta
|
|
||||||
setup_pasta_options() {
|
|
||||||
context_setup_host host
|
|
||||||
|
|
||||||
layout_pasta_simple
|
|
||||||
}
|
|
||||||
|
|
||||||
# setup_passt_in_ns() - Set up namespace (with pasta), run qemu and passt into it
|
# setup_passt_in_ns() - Set up namespace (with pasta), run qemu and passt into it
|
||||||
setup_passt_in_ns() {
|
setup_passt_in_ns() {
|
||||||
context_setup_host host
|
context_setup_host host
|
||||||
|
@ -285,11 +273,6 @@ teardown_build() {
|
||||||
teardown_context_watch ${PANE_HOST} host
|
teardown_context_watch ${PANE_HOST} host
|
||||||
}
|
}
|
||||||
|
|
||||||
# teardown_distro() - Nothing to do, yet
|
|
||||||
teardown_distro() {
|
|
||||||
:
|
|
||||||
}
|
|
||||||
|
|
||||||
# teardown_passt() - Kill qemu, remove passt PID file
|
# teardown_passt() - Kill qemu, remove passt PID file
|
||||||
teardown_passt() {
|
teardown_passt() {
|
||||||
kill $(cat "${STATESETUP}/qemu.pid")
|
kill $(cat "${STATESETUP}/qemu.pid")
|
||||||
|
@ -311,12 +294,6 @@ teardown_pasta() {
|
||||||
teardown_context_watch ${PANE_NS} unshare ns
|
teardown_context_watch ${PANE_NS} unshare ns
|
||||||
}
|
}
|
||||||
|
|
||||||
# teardown_pasta_options() - Tear down pasta and host context, no namespace
|
|
||||||
teardown_pasta_options() {
|
|
||||||
teardown_context_watch ${PANE_HOST} host
|
|
||||||
teardown_context_watch ${PANE_PASST} passt
|
|
||||||
}
|
|
||||||
|
|
||||||
# teardown_passt_in_ns() - Exit namespace, kill qemu and pasta, remove pid file
|
# teardown_passt_in_ns() - Exit namespace, kill qemu and pasta, remove pid file
|
||||||
teardown_passt_in_ns() {
|
teardown_passt_in_ns() {
|
||||||
context_run ns kill $(cat "${STATESETUP}/qemu.pid")
|
context_run ns kill $(cat "${STATESETUP}/qemu.pid")
|
||||||
|
|
38
test/lib/setup_ugly
Executable file
38
test/lib/setup_ugly
Executable file
|
@ -0,0 +1,38 @@
|
||||||
|
#!/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/setup_ugly - Setup functions using screen-scraping instead of context
|
||||||
|
#
|
||||||
|
# Copyright (c) 2022 Red Hat GmbH
|
||||||
|
# Author: Stefano Brivio <sbrivio@redhat.com>
|
||||||
|
|
||||||
|
# setup_distro() - Set up pane layout for distro tests
|
||||||
|
setup_distro() {
|
||||||
|
layout_host
|
||||||
|
}
|
||||||
|
|
||||||
|
# setup_pasta_options() - Set up layout and host context without starting pasta
|
||||||
|
setup_pasta_options() {
|
||||||
|
context_setup_host host
|
||||||
|
|
||||||
|
layout_pasta_simple
|
||||||
|
}
|
||||||
|
|
||||||
|
# teardown_distro() - Nothing to do, yet
|
||||||
|
teardown_distro() {
|
||||||
|
:
|
||||||
|
}
|
||||||
|
|
||||||
|
# teardown_pasta_options() - Tear down pasta and host context, no namespace
|
||||||
|
teardown_pasta_options() {
|
||||||
|
teardown_context_watch ${PANE_HOST} host
|
||||||
|
teardown_context_watch ${PANE_PASST} passt
|
||||||
|
}
|
||||||
|
|
2
test/run
2
test/run
|
@ -39,10 +39,12 @@ COMMIT="$(git log --oneline --no-decorate -1)"
|
||||||
|
|
||||||
. lib/util
|
. lib/util
|
||||||
. lib/setup
|
. lib/setup
|
||||||
|
. lib/setup_ugly
|
||||||
. lib/context
|
. lib/context
|
||||||
. lib/term
|
. lib/term
|
||||||
. lib/perf_report
|
. lib/perf_report
|
||||||
. lib/layout
|
. lib/layout
|
||||||
|
. lib/layout_ugly
|
||||||
. lib/test
|
. lib/test
|
||||||
. lib/video
|
. lib/video
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue