summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile14
-rwxr-xr-xscripts/check-qemu-install58
2 files changed, 70 insertions, 2 deletions
diff --git a/Makefile b/Makefile
index a11e88b5..c5444814 100644
--- a/Makefile
+++ b/Makefile
@@ -28,6 +28,11 @@ test: checkiso
test-no-interfaces: checkiso
scripts/check-qemu-install --debug --configd --smoketest --uefi --no-interfaces --cpu 4 --memory 8 build/live-image-amd64.hybrid.iso
+.PHONY: test-no-interfaces-no-vpp
+.ONESHELL:
+test-no-interfaces-no-vpp: checkiso
+ scripts/check-qemu-install --debug --configd --smoketest --uefi --no-interfaces --no-vpp build/live-image-amd64.hybrid.iso
+
.PHONY: test-interfaces
.ONESHELL:
test-interfaces: checkiso
@@ -36,12 +41,17 @@ test-interfaces: checkiso
.PHONY: test-vpp
.ONESHELL:
test-vpp: checkiso
- scripts/check-qemu-install --debug --configd --match="vpp" --smoketest --uefi --cpu 4 --memory 8 build/live-image-amd64.hybrid.iso
+ scripts/check-qemu-install --debug --configd --match="vpp" --smoketest --uefi --cpu 4 --memory 8 --huge-page-size 2M --huge-page-count 1800 build/live-image-amd64.hybrid.iso
.PHONY: testc
.ONESHELL:
testc: checkiso
- scripts/check-qemu-install --debug --configd --cpu 2 --memory 7 --configtest build/live-image-amd64.hybrid.iso $(filter-out $@,$(MAKECMDGOALS))
+ scripts/check-qemu-install --debug --configd --match="!vpp" --cpu 2 --memory 7 --configtest build/live-image-amd64.hybrid.iso $(filter-out $@,$(MAKECMDGOALS))
+
+.PHONY: testcvpp
+.ONESHELL:
+testcvpp: checkiso
+ scripts/check-qemu-install --debug --configd --match="vpp" --cpu 4 --memory 8 --huge-page-size 2M --huge-page-count 1800 --configtest build/live-image-amd64.hybrid.iso $(filter-out $@,$(MAKECMDGOALS))
.PHONY: testraid
.ONESHELL:
diff --git a/scripts/check-qemu-install b/scripts/check-qemu-install
index 3d4a7182..53e1c74d 100755
--- a/scripts/check-qemu-install
+++ b/scripts/check-qemu-install
@@ -99,6 +99,10 @@ parser.add_argument('--cpu', help='Set QEMU CPU', type=int, default=2)
parser.add_argument('--memory', help='Set QEMU memory', type=int, default=4)
parser.add_argument('--vyconf', help='Execute testsuite with vyconfd', action='store_true',
default=False)
+parser.add_argument('--no-vpp', help='Execute testsuite without VPP tests',
+ action='store_true', default=False)
+parser.add_argument('--huge-page-size', help='Huge page size (e.g., 2M, 1G)', type=str)
+parser.add_argument('--huge-page-count', help='Number of huge pages to allocate', type=int)
args = parser.parse_args()
@@ -411,6 +415,22 @@ try:
exit(1)
#################################################
+ # Configure boot options if required
+ #################################################
+ if args.huge_page_size and args.huge_page_count:
+ c.sendline('configure')
+ c.expect(cfg_mode_prompt)
+ c.sendline(f'set system option kernel memory hugepage-size {args.huge_page_size} hugepage-count {args.huge_page_count}')
+ c.expect(cfg_mode_prompt)
+ c.sendline('set system option kernel disable-mitigations')
+ c.expect(cfg_mode_prompt)
+ c.sendline('commit')
+ c.expect(cfg_mode_prompt)
+ c.sendline('save')
+ c.expect(cfg_mode_prompt)
+ c.sendline('exit')
+ c.expect(op_mode_prompt)
+ #################################################
# Installing into VyOS system
#################################################
log.info('Starting installer')
@@ -526,6 +546,14 @@ try:
loginVM(c, log)
+ #################################################
+ # Boot options require a reboot
+ #################################################
+ if args.huge_page_size and args.huge_page_count:
+ log.info('Rebooting to apply kernel boot options')
+ c.sendline('reboot now')
+ loginVM(c, log)
+
################################################
# Always load the WiFi simulation module
################################################
@@ -570,6 +598,12 @@ try:
c.expect(op_mode_prompt)
c.sendline('show system memory')
c.expect(op_mode_prompt)
+ c.sendline('show system memory detail | no-more')
+ c.expect(op_mode_prompt)
+ c.sendline('show configuration commands | match kernel')
+ c.expect(op_mode_prompt)
+ c.sendline('cat /proc/cmdline')
+ c.expect(op_mode_prompt)
c.sendline('show version all | grep -e "vpp" -e "vyos-1x"')
c.expect(op_mode_prompt)
@@ -806,6 +840,10 @@ try:
# remove interface tests as they consume a lot of time
c.sendline('sudo rm -f /usr/libexec/vyos/tests/smoke/cli/test_interfaces_*')
c.expect(op_mode_prompt)
+ if args.no_vpp:
+ # remove VPP tests
+ c.sendline('sudo rm -f /usr/libexec/vyos/tests/smoke/cli/test_vpp*')
+ c.expect(op_mode_prompt)
if args.vyconf:
c.sendline('sudo /usr/libexec/vyos/set_vyconf_backend.py --no-prompt &> /dev/null')
@@ -837,6 +875,26 @@ try:
# else, run configtest suite
elif args.configtest:
+ # Remove config-tests that we don't want to run
+ if args.match:
+ if args.match.startswith("!"):
+ # Exclude mode — delete only the matched names
+ names = args.match[1:].split("|")
+ match_str = '-o '.join([f'-name "{name}"' for name in names])
+ cleanup_config_dir_cmd = f'sudo find /usr/libexec/vyos/tests/config -mindepth 1 -maxdepth 1 \\( {match_str} \\) -exec rm -rf {{}} +'
+ cleanup_config_tests_dir_cmd = f'sudo find /usr/libexec/vyos/tests/config-tests -mindepth 1 -maxdepth 1 \\( {match_str} \\) -exec rm -rf {{}} +'
+ else:
+ # Include mode — keep only the matched names, delete the rest
+ names = args.match.split("|")
+ match_str = '-o '.join([f'-name "{name}"' for name in names])
+ cleanup_config_dir_cmd = f'sudo find /usr/libexec/vyos/tests/config -mindepth 1 -maxdepth 1 ! \\( {match_str} \\) -exec rm -rf {{}} +'
+ cleanup_config_tests_dir_cmd = f'sudo find /usr/libexec/vyos/tests/config-tests -mindepth 1 -maxdepth 1 ! \\( {match_str} \\) -exec rm -rf {{}} +'
+
+ c.sendline(cleanup_config_dir_cmd)
+ c.expect(op_mode_prompt)
+ c.sendline(cleanup_config_tests_dir_cmd)
+ c.expect(op_mode_prompt)
+
log.info('Adding a legacy WireGuard default keypair for migrations')
c.sendline('sudo mkdir -p /config/auth/wireguard/default')
c.expect(op_mode_prompt)